您好,登錄后才能下訂單哦!
小編給大家分享一下怎么基于vue.js實現(xiàn)分頁查詢功能,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以創(chuàng)建可維護性和可測試性更強的代碼庫,Vue允許可以將一個網(wǎng)頁分割成可復(fù)用的組件,每個組件都包含屬于自己的HTML、CSS、JavaScript,以用來渲染網(wǎng)頁中相應(yīng)的地方,所以越來越多的前端開發(fā)者使用vue。
具體內(nèi)容如下
最新項目有一個分頁功能,畫面風格很簡樸給的樣圖就用【1】表示頁碼了, 因此,我沒有上網(wǎng)上找插件,自己簡單的做了一個。作為菜鳥,代碼可能有點青澀,請見諒。
除了vue我還引用了Bootstrap的類和圖標
html
<div class="paging"> <ul class="pagination" > <li class="page-li" v-if="page>1"><a href="javascript:void(0);" @click="firstpg()" ><span class="glyphicon glyphicon-step-backward"></span></a></li> <li class="page-li" v-else></li> <li class="page-li" v-if="page>1"><a href="javascript:void(0);" @click="up()" ><span class="glyphicon glyphicon-chevron-left"></span></a></li> <li class="page-li" v-else></li> <li class="page-li" v-if="showup>0"><a href="javascript:void(0);" @click="showmore1()" >...</a></li> <li class="page-li" v-else></li> <li v-for="i in pages" v-if="i>showup&&i<showdown"><a href="javascript:void(0);" @click="setpage(i)" :class="{colorred:i==page}" >[{{i}}]</a></li> <li class="page-li" v-if="showdown<=pages"><a href="javascript:void(0);" @click="showmore2()" >...</a></li> <li class="page-li" v-else></li> <li class="page-li" v-if="page<pages"><a href="javascript:void(0);" @click="down()" ><span class="glyphicon glyphicon-chevron-right"></span></a></li> <li class="page-li" v-else></li> <li class="page-li" v-if="page<pages"><a href="javascript:void(0);" @click="lastpg()" ><span class="glyphicon glyphicon-step-forward"></span></a></li> <li class="page-li" v-else></li> </ul> </div>
js
const listData = { initcount : 0, //選中的頁號 page : 1, //顯示頁碼下限 showdown : 0, //顯示頁碼上限 showup : 0, }; $(function() { new Vue({ el : ‘#manageArea', data : listData, methods : { setpage : setpage, up : up, down : down, firstpg : firstpg, lastpg : lastpg, showmore1 : showmore1, showmore2 : showmore2, }, }); setShowdown(); setShowup(); initAjax(); }); //選中的頁號 function setpage(i) { listData.page = i; setShowdown(); setShowup(); initAjax(); } //向上翻一頁 function up() { if (listData.page > 1) { listData.page = listData.page - 1; setShowdown(); setShowup(); initAjax(); } } //向下翻一頁 function down() { if (listData.page < listData.pages) { listData.page = listData.page + 1; setShowdown(); setShowup(); initAjax(); } } //直接到首頁 function firstpg() { if (listData.page > 1) { listData.page = 1; setShowdown(); setShowup(); initAjax(); } } //直接到尾頁 function lastpg() { if (listData.page < listData.pages) { listData.page = listData.pages; setShowdown(); setShowup(); initAjax(); } } //往前翻三頁 function showmore1() { listData.showdown -= 3; listData.showup -= 3; } //往后翻三頁 function showmore2() { listData.showdown += 3; listData.showup += 3; } //設(shè)置顯示的頁碼下限 function setShowdown() { listData.showdown = listData.page + 2; } //設(shè)置顯示的頁碼上限 function setShowup() { listData.showup = listData.page - 2; }
這樣通過把選中的頁碼傳到后臺 計算出 limit 開始條數(shù)的值 如顯示20條 開始值就是 (page-1)*20;就可以了。從代碼到描述都很簡陋,還請大家對我的錯誤不足進行指正。
以上是“怎么基于vue.js實現(xiàn)分頁查詢功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責聲明:本站發(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)容。