vue實(shí)現(xiàn)分頁(yè)組件

填坑之路繼續(xù)哈~

首先來(lái)張圖,有圖有真相

pager.png

不喜就噴哈~

參數(shù)

分頁(yè)需要的字段:當(dāng)前頁(yè)(curPage)娶牌,每頁(yè)大小(pageSize),總頁(yè)數(shù)(total)
作為一個(gè)組件,所以以上這些參數(shù)最好是從父組件傳遞過(guò)來(lái)迟几,可以如下定義:

...
props:[
      "pageSize","curPage","total"
]
...

按鈕顯示

另外還需要用一些屬性控制按鈕的是否顯示,比如:當(dāng)前為第一頁(yè)時(shí)不顯示上一頁(yè)和首頁(yè)按鈕栏笆,當(dāng)前為最后一頁(yè)時(shí)不顯示下一頁(yè)和尾頁(yè)按鈕:

...
    data () {
        return {
                       ...
            "showFirstPage":true,
            "showLastPage":true,
            "showPrevPage":true,
            "showNextPage":true,
                      ...
        }
    }
...

頁(yè)面可以如下設(shè)置:

<a href="javascript:void(0);" v-show="showFirstPage">首頁(yè)</a>
<a href="javascript:void(0);" v-show="showPrevPage" >上一頁(yè)</a>
<a href="javascript:void(0);" v-show="showNextPage" >下一頁(yè)</a>
<a href="javascript:void(0);" v-show="showLastPage" >尾頁(yè)</a>

跳轉(zhuǎn)頁(yè)面大小

頁(yè)面大小不能用pageSize來(lái)控制类腮,需要重新綁定一個(gè)變量:

...
data () {
   return {
       ...
      "rowNum":this.pageSize
    }
}
...

頁(yè)面部分可以這么寫:

<select v-model="rowNum">
    <option value="10">10</option>
    <option selected="selected" value="20">20</option>
    <option value="50">50</option>
    <option value="100">100</option>
</select>

顯示邏輯:

...
    this.showFirstPage = this.curPage> 1
    this.showLastPage = this.curPage< this.total
    this.showPrevPage = this.curPage> 1
    this.showNextPage = this.curPage< this.total
...

頁(yè)面跳轉(zhuǎn)

當(dāng)頁(yè)數(shù)太多時(shí),頁(yè)面跳轉(zhuǎn)就必不可少了蛉加,可以使用<input>標(biāo)簽讓用戶輸入蚜枢,當(dāng)然需要驗(yàn)證輸入是否準(zhǔn)確,
首先需要的屬性不能少:

...
data () {
        return {
            "gotoPage":"",
                    ...
          }
}
...

頁(yè)面代碼:

<input type="text" v-model="gotoPage" />
<a href="javascript:void(0);"  >跳轉(zhuǎn)</a>

還有针饥,使用前得做判斷:

...
if(this.gotoPage && /[1-9][0-9]*/.test(this.gotoPage)){
...
}
...

唉厂抽,沒(méi)口水了。丁眼。筷凤。其實(shí),說(shuō)了這么多户盯,就一句話:吾寫這份代碼不易嵌施,希汝珍惜對(duì)待 ^_^饲化。。吗伤。
好了吃靠,關(guān)門,放代碼:

代碼在此

template

<template>
    <div class="pager">     
        <a href="javascript:void(0);" v-show="showFirstPage" v-on:click="firstPage" >首頁(yè)</a>
        <a href="javascript:void(0);" v-show="showPrevPage" v-on:click="prevPage" >上一頁(yè)</a>
        <a href="javascript:void(0);" v-show="showNextPage" v-on:click="nextPage" >下一頁(yè)</a>
        <a href="javascript:void(0);" v-show="showLastPage" v-on:click="lastPage" >尾頁(yè)</a>
        <div>
            <select v-model="rowNum">
                <option value="10">10</option>
                <option selected="selected" value="20">20</option>
                <option value="50">50</option>
                <option value="100">100</option>
            </select>
        </div>      
        <span>{{curPage}}/{{total}}</span>
        <div class="goto">
            <input type="text" v-model="gotoPage" />
            <a href="javascript:void(0);" v-on:click="gotoNextPage" >跳轉(zhuǎn)</a>
        </div>
    </div>
</template>

script

<script>
export default {
    mounted() {
        this.$nextTick(() => { this.initPager() }) //需要延遲初始化
    },
    name: 'Pager',
    data () {
        return {
            "gotoPage":"",
            "showFirstPage":true,
            "showLastPage":true,
            "showPrevPage":true,
            "showNextPage":true,
            "rowNum":this.pageSize
        }
    },
    methods:{
        nextPage(){//下一頁(yè)            
            this.$emit('setPage', this.curPage+ 1 ) //調(diào)用父組件方法
        },
        prevPage(){//上一頁(yè)
            this.$emit('setPage', this.curPage- 1 ) //調(diào)用父組件方法
        },
        gotoNextPage(){//跳轉(zhuǎn)頁(yè)面
            if(this.gotoPage && /[1-9][0-9]*/.test(this.gotoPage)){             
                var pg = parseInt(this.gotoPage)
                if(pg > 0 && pg <= this.pageSize){
                    this.$emit('setPage', pg ) //調(diào)用父組件方法
                }else{
                    this.gotoPage = ""
                }
            }else{
                this.gotoPage = ""
            }
        },      
        firstPage(){
            this.$emit('setPage', 1 ) //調(diào)用父組件方法
        },
        lastPage(){
            this.$emit('setPage', this.total ) //調(diào)用父組件方法
        },
        rowNumChanged(){
            this.$emit('setRowNum', this.rowNum )
        },
        initPager(){
            this.showFirstPage = this.curPage> 1
            this.showLastPage = this.curPage< this.total
            this.showPrevPage = this.curPage> 1
            this.showNextPage = this.curPage< this.total
            this.gotoPage = ""
        }
    },
    props:[
        "pageSize","curPage","total"
    ],
    watch:{
        'rowNum':'rowNumChanged' //監(jiān)控rowNum
    }
}
</script>

css

<style>
.pager>span,.pager>a,.pager>select,.pager>div{
    float: left;
    margin-left: 10px;
}

.pager{
    width: 600px;
    margin: 0 auto;
    margin-top: 10px;
    height: 48px;
    line-height: 48px;
    margin-bottom: 40px;
}

.pager input,.pager select{
    height:40px; 
    line-height:40px;
    outline:none; 
    border:1px solid #888; 
    padding:10px; 
    box-sizing:border-box;
}
.pager input{
    width: 50px;
}
.pager .goto{
    margin-left: 20px;
}
.pager a{
    color: black;
    font-weight: bold;
    text-decoration: none;
}
.pager a:hover{
    color: green;
}

</style>

好了足淆,以上就是組件的全部代碼



那么父組件該如何調(diào)用呢巢块?嘿嘿

分頁(yè)組件的調(diào)用

template

<template>
...
<Pager
v-if="!dataChanged" 
ref="pager"
:pageSize="pageSize" 
:page="curPage" 
:total="total"  
@setPage="gotoPage"
 @setRowNum="changeRowNum" />
...
</template>

其中dataChanged用來(lái)刷新組件的,參考:vue強(qiáng)制刷新組件

其中setPage和setRowNum分別對(duì)應(yīng)父組件的方法:gotoPage巧号,changeRowNum族奢,參考:vue2.0父子組件以及非父子組件如何通信

script

import Pager from '@/components/Pager'
...
export default{ 
  ...
    data(){
        return {
            curPage:1,//當(dāng)前頁(yè)
            total:0,//總共頁(yè)數(shù)
            pageSize:20,//每頁(yè)記錄數(shù) 
            dataChanged:false
        }
    },
    components:{
       "Pager":Pager
    }
        methods:{
          refresh(){//用于刷新組件,需手動(dòng)調(diào)用
              this.dataChanged = true
                this.$nextTick(() => {
                this.dataChanged = false
                })
           },
          gotoPage(page){
             ...
         },
         changeRowNum(pageSize){
                ...
           }
        }
  ...
}

好了丹鸿,真的完了~

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末越走,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子靠欢,更是在濱河造成了極大的恐慌廊敌,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,978評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件门怪,死亡現(xiàn)場(chǎng)離奇詭異骡澈,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)掷空,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門肋殴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人坦弟,你說(shuō)我怎么就攤上這事护锤。” “怎么了酿傍?”我有些...
    開封第一講書人閱讀 156,623評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵蔽豺,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我拧粪,道長(zhǎng),這世上最難降的妖魔是什么沧侥? 我笑而不...
    開封第一講書人閱讀 56,324評(píng)論 1 282
  • 正文 為了忘掉前任可霎,我火速辦了婚禮,結(jié)果婚禮上宴杀,老公的妹妹穿的比我還像新娘癣朗。我一直安慰自己,他們只是感情好旺罢,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評(píng)論 5 384
  • 文/花漫 我一把揭開白布旷余。 她就那樣靜靜地躺著绢记,像睡著了一般。 火紅的嫁衣襯著肌膚如雪正卧。 梳的紋絲不亂的頭發(fā)上蠢熄,一...
    開封第一講書人閱讀 49,741評(píng)論 1 289
  • 那天,我揣著相機(jī)與錄音炉旷,去河邊找鬼签孔。 笑死,一個(gè)胖子當(dāng)著我的面吹牛窘行,可吹牛的內(nèi)容都是我干的饥追。 我是一名探鬼主播,決...
    沈念sama閱讀 38,892評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼罐盔,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼但绕!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起惶看,我...
    開封第一講書人閱讀 37,655評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤捏顺,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后碳竟,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體草丧,經(jīng)...
    沈念sama閱讀 44,104評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年莹桅,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了昌执。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,569評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡诈泼,死狀恐怖懂拾,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情铐达,我是刑警寧澤岖赋,帶...
    沈念sama閱讀 34,254評(píng)論 4 328
  • 正文 年R本政府宣布,位于F島的核電站瓮孙,受9級(jí)特大地震影響唐断,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜杭抠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評(píng)論 3 312
  • 文/蒙蒙 一脸甘、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧偏灿,春花似錦丹诀、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)硝桩。三九已至,卻和暖如春枚荣,著一層夾襖步出監(jiān)牢的瞬間碗脊,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工棍弄, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留望薄,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,260評(píng)論 2 360
  • 正文 我出身青樓呼畸,卻偏偏與公主長(zhǎng)得像痕支,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子蛮原,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容