溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

vue分頁器組件編寫方法詳解

發(fā)布時間:2020-09-03 13:24:18 來源:腳本之家 閱讀:108 作者:web_xiaolei 欄目:web開發(fā)

使用vue編寫的分頁器組件,支持輸入頁碼跳轉(zhuǎn),效果如圖:

1、點擊前五頁:

vue分頁器組件編寫方法詳解

2、點擊中間部分頁面

vue分頁器組件編寫方法詳解

3、點擊第一頁,上一頁按鈕失效,點擊最后一頁,下一頁按鈕失效

vue分頁器組件編寫方法詳解

組件調(diào)用:

//html調(diào)用 參數(shù):pageSize(總頁數(shù));pageNo(當(dāng)前頁)
<pager :pageSize="pageSize" v-model="pageNo" @on-jump="jump"></pager>

//組件引入
import pager from '../../component/pager/pager.vue'

//組件調(diào)用聲明
components:{ pager}

//參數(shù)
data(){
 return {
  pageSize: 30,
  pageNo: 2
 }
}

//接收跳轉(zhuǎn)事件
methods:{
 jump(id){
  console.log(id)
 },
}

組件編寫

pager.vue:

<template>
 <div class="pager-wrapper" ref="pager">
  <div class="pager-box">
   <a class="pager-prev" :class="{'pager-disabled':prevDisable}" href="javascript:;" @click="jumpPrev()">上一頁</a>
   <template v-for="i in pageSize">
    <span v-if="i==pageNo" class="pager-curr">
     <em class="pager-em"></em><em>{{i}}</em>
    </span>
    <a v-else-if="pageNo<5&&(i)<6" href="javascript:;" @click="jump(i)">
     {{i}}
    </a>
    <a v-else-if="pageSize<7||i==1||i==pageSize||(pageNo-2<=i&&i<=pageNo+2)" href="javascript:;" @click="jump(i)">
     {{i}}
    </a>
    <template v-else>
     <span v-if="pageNo<5&&i==6" class="pager-spr">…</span>
     <span v-if="pageNo==4&&i==7" class="pager-spr">…</span>
     <span v-if="pageNo>4&&i==pageNo-3" class="pager-spr">…</span>
     <span v-if="pageNo>4&&i==pageNo+3" class="pager-spr">…</span>
    </template>
   </template>
   <a class="pager-next" :class="{'pager-disabled':nextDisable}" href="javascript:;" @click="jumpNext()">下一頁</a>
  </div>
  <div class="pager-input">
   <input type="text" v-model="jumpPage">
   <a class="pager-btn-go" href="javascript:;" @click="Go()">GO</a>
  </div>
 </div>
</template>
<script>
export default {
 model:{ //通過v-model傳過來的參數(shù)
  prop: 'pageNo',
  event: 'jumpPage'
 },
 props:{
  pageSize:{
   type: Number,
   default: 1
  },
  pageNo:{ //通過v-model傳過來的參數(shù)
   type: Number,
   default: 1
  }
 },
 data(){
  return {
   jumpPage:'' //避免操作props參數(shù)
  }
 },
 computed: {
  prevDisable: function(){ //“上一頁”按鈕是否可點
   if(this.pageNo > 1){
    return false;
   }else{
    return true
   }
  },
  nextDisable: function(){ //“下一頁”按鈕是否可點
   if(this.pageNo < this.pageSize && this.pageSize > 1){
    return false;
   }else{
    return true;
   }
  },
 },
 methods: {
  jumpPrev: function(){ //點擊上一頁
   if(this.pageNo == 1){
    return ;
   }else{
    this.$emit('jumpPage',this.pageNo-1);
    this.$emit('on-jump',this.pageNo-1);
   }
  },
  jumpNext: function(){ //點擊下一頁
   if(this.pageNo == this.pageSize){
    return ;
   }else{
    this.$emit('jumpPage',this.pageNo+1); //修改當(dāng)前頁碼
    this.$emit('on-jump',this.pageNo+1); //跳轉(zhuǎn)
   }
  },
  jump: function(id){ //直接跳轉(zhuǎn)
   if(id>this.pageSize){ 
    id=this.pageSize;
   }
   this.jumpPage = '';
   this.$emit('jumpPage',id); //修改當(dāng)前頁碼
   this.$emit('on-jump',id); //跳轉(zhuǎn)
  },
  Go: function(){
   if(this.jumpPage==''){ //判空處理
    return ;
   }else if(/^\d*$/.test(parseInt(this.jumpPage))){ //填寫數(shù)字才能跳轉(zhuǎn)
    this.jump(parseInt(this.jumpPage));
    this.jumpPage = '';
   }else{
    this.jumpPage = '';
    return ;
   }
  }
 }
}
</script>

完整代碼可下載:vue分頁器組件

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI