精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

如何通過vue實現一款簡單通用的翻頁組件

開發 前端
翻到某個列表的某一頁之后,點擊某一項到編輯頁,編輯完成后希望能夠返回到跳轉之前的那一頁。這個需求如果僅僅用上面的pager組件,實現起來就不是很方便。也許有人會說結合vuex可以,但是這樣的話需要在state中記錄下跳轉前的頁碼。假如有很多個翻頁列表,就需要記錄多個,這顯然并不優雅。

預覽

先上一波效果圖:

 基本元素

首先,翻頁組件(以下稱“pager組件”)一般擁有的元素有:

  • 上一頁
  • ***頁
  • 中間顯示的頁碼
  • ***一頁
  • 下一頁

初始化時需要的配置有:

  • totalPage(總頁數)
  • initPage(初始頁)
  • showPrev(是否顯示上一頁)
  • showNext(是否顯示下一頁)
  • showItems(中間顯示幾頁)
  • showJump(是否顯示跳轉到第幾頁)

這些可以通過vue的props來接收。

另外,pager組件本身需要有一個記錄當前頁的currentPage,pages數組用來容納中間顯示的頁碼,jumpPage綁定輸入的跳轉頁碼。

基本實現

對應的代碼為:

  1. <template> 
  2.     <div class="pager-wrapper" v-if="totalPage > 0"
  3.         <div class="pager-pages"
  4.             <a v-show="currentPage > 1 && showPrev" @click="go(currentPage - 1)">上一頁</a> 
  5.             <a :class="{active: currentPage == 1 ? true : false}" @click="go(1)">1</a> 
  6.             <strong v-show="pages[0] > 2">...</strong> 
  7.             <a v-for="page in pages" :class="{active: currentPage == page ? true : false}" @click="go(page)">{{page}}</a> 
  8.             <strong v-show="pages[pages.length-1] < totalPage - 1">...</strong> 
  9.             <a v-if="totalPage > 1" :class="{active: currentPage == totalPage ? true : false}" @click="go(totalPage)">{{totalPage}}</a> 
  10.             <a v-show="currentPage < totalPage && showNext" @click="go(currentPage + 1)">下一頁</a> 
  11.         </div> 
  12.         <div v-if="showJump" v-show="totalPage > 1" class="pager-jump"
  13.             <span>共<em class="jump-total">{{totalPage}}</em>頁 ,跳至</span> 
  14.             <input type="number" min="1" :max="totalPage" v-model="jumpPage" class="jump-input"
  15.             <span>頁</span> 
  16.             <a @click="go(jumpPage)">確定</a> 
  17.         </div> 
  18.     </div> 
  19. </template> 
  20. <script> 
  21.   export default { 
  22.         props: { 
  23.             totalPage: { // 總頁數 
  24.                 type: Number, 
  25.                 default: 1, 
  26.                 required: true 
  27.             }, 
  28.             showItems: { // 顯示出來的頁數,如: 1 ... 34[5]67 ... 10 
  29.                 type: Number, 
  30.                 default: 5 
  31.             }, 
  32.             showPrev: { // 是否顯示“上一頁” 
  33.                 type: Boolean, 
  34.                 defaulttrue 
  35.             }, 
  36.             showNext: { // 是否顯示“下一頁” 
  37.                 type: Boolean, 
  38.                 defaulttrue 
  39.             }, 
  40.             showJump: { // 是否顯示“跳轉” 
  41.                 type: Boolean, 
  42.                 defaulttrue 
  43.             }, 
  44.             initPage: { 
  45.                 type: Number, 
  46.                 default: 1 
  47.             } 
  48.         }, 
  49.         data () { 
  50.             return { 
  51.                 currentPage: 0, 
  52.                 pages: [], 
  53.                 jumpPage: 0, 
  54.             } 
  55.         }, 
  56.         created () {// 初始化時currentPage賦值 
  57.             this.currentPage = this.initPage 
  58.         } 
  59.         methods: { 
  60.             go (page) { 
  61.                 if(page < 1) { 
  62.                     page = 1 
  63.                 } 
  64.                 if(page > this.totalPage) { 
  65.                     page = this.totalPage 
  66.                 } 
  67.                 if(page === this.currentPage) { 
  68.                     return 
  69.                 } 
  70.                 this.currentPage = parseInt(page,10) 
  71.                 this.$emit('go-page',{ 
  72.                     page: this.currentPage 
  73.                 }) 
  74.             } 
  75.         }, 
  76.         watch: { 
  77.             currentPage (newVal) { 
  78.                 this.jumpPage = newVal 
  79.             }, 
  80.             initPage (newVal) { 
  81.                 if(this.currentPage !== newVal) { 
  82.                     this.currentPage = newVal 
  83.                 } 
  84.             } 
  85.         } 
  86.     } 
  87. </script>  

接下來就是pages數組的值如何獲取到。由于pages始終是跟當前頁currentPage以及配置中需要顯示的showItems強相關的,那么完全可以將pages改為計算屬性:

  1. computed: { 
  2.     pages () { 
  3.         // 根據起始頁碼和結束頁碼得到頁碼數組 
  4.         let getPages = (start,end) => { 
  5.             if(start <= 1 || start > end || start >= this.totalPage) { 
  6.                 start = 2 
  7.             } 
  8.             if(end >= this.totalPage || end < start || end <= 1) { 
  9.                 end = this.totalPage - 1 
  10.             } 
  11.             let arr = [] 
  12.             for(let i = start; i <= end; i++) { 
  13.                 arr.push(i) 
  14.             } 
  15.             return arr 
  16.         } 
  17.         let counts = this.showItems 
  18.         if(this.totalPage < counts + 2) { 
  19.             return getPages(2,this.totalPage) 
  20.         } else { 
  21.             if(this.currentPage <= Math.ceil(counts/2)) { 
  22.                 return getPages(2,counts) 
  23.             } else if(this.currentPage >= this.totalPage - Math.floor(counts/2)) { 
  24.                 return getPages(this.totalPage + 1 - counts,this.totalPage - 1) 
  25.             } else { 
  26.                 let half = Math.ceil(counts/2) - 1 
  27.                 let end = this.currentPage + half 
  28.                 if(counts % 2 === 0) { 
  29.                     end++ 
  30.                 } 
  31.                 return getPages(this.currentPage - half,end
  32.             } 
  33.         } 
  34.     } 

 功能拓展

到這里一個普通的翻頁組件基本上就實現了(樣式自己可以去定制)。但是很多時候(特別是一些管理后臺),結合vue-router做成SPA,通常會有這樣的需求:

翻到某個列表的某一頁之后,點擊某一項到編輯頁,編輯完成后希望能夠返回到跳轉之前的那一頁。

這個需求如果僅僅用上面的pager組件,實現起來就不是很方便。也許有人會說結合vuex可以,但是這樣的話需要在state中記錄下跳轉前的頁碼。假如有很多個翻頁列表,就需要記錄多個,這顯然并不優雅。

不過因為vue-router實現的優雅,我們要滿足上面的需求也很簡單:

首先props上增加mode配置,由于當mode為params時,跳轉需要知道是在哪一個路由下,所以:

  1. mode: { 
  2.     type: String, 
  3.     default'event' // 'event' | 'query' | 'params' 
  4. }, 
  5. routeName: { 
  6.     type: String 

 然后再在實際跳轉的邏輯方法go(page)里面,做點更改:

  1. go (page) { 
  2.     if(page < 1) { 
  3.         page = 1 
  4.     } 
  5.     if(page > this.totalPage) { 
  6.         page = this.totalPage 
  7.     } 
  8.     if(page === this.currentPage) { 
  9.         return 
  10.     } 
  11.     this.currentPage = parseInt(page,10) 
  12.     if(this.mode == 'query') { 
  13.         let query = this.$route.query 
  14.         query.page = this.currentPage 
  15.         this.$router.go({query: query}) 
  16.     } else if(this.mode == 'params') { 
  17.         let params = this.$route.params 
  18.         params.page = this.currentPage 
  19.         this.$router.go({name: this.routeName,params: params}) 
  20.     } else { 
  21.         this.$emit('go-page',{ 
  22.             page: this.currentPage 
  23.         }) 
  24.     } 

這樣基本上就完成了一個簡單且通用的翻頁組件啦,接下里就是發不到倉庫里供大家使用了。

本文最終實現的翻頁組件已經發布,大家可以看一波源碼:

vue-simple-pager

總結

總體上講的比較淺顯,希望能有幫助。

責任編輯:龐桂玉 來源: segmentfault
相關推薦

2015-11-27 09:18:11

AngularJSWeb應用

2023-01-29 07:49:57

2025-03-05 10:01:44

2014-12-16 10:11:22

2017-03-06 11:02:59

產品軟件Power Desig

2020-12-03 09:00:02

Java外賣系統

2021-02-20 07:02:24

Vue.js組件開發技術

2023-03-31 14:51:46

CSS圖案背景開發

2024-06-11 00:00:00

Java線程安全緩存組件

2020-12-03 09:33:58

前端開發工具

2021-07-07 06:52:17

云圖word-cloud工具

2023-07-03 08:25:54

2011-06-17 11:22:33

jQueryjQuery插件

2020-12-29 05:26:27

視頻播放器Vuevideo

2022-02-28 08:19:25

圖片預覽動畫前端

2022-02-08 15:55:00

Vue組件庫Vue Demi

2020-12-07 11:50:14

Java學習系統eclipse

2009-05-11 15:12:03

網管軟件產品摩卡軟件

2014-06-20 10:32:42

APP上癮設計

2022-04-18 19:02:53

chrome擴展瀏覽器
點贊
收藏

51CTO技術棧公眾號

高清一区二区| 在线a免费看| 国产欧美亚洲一区| 亚洲人成电影网| 一本色道久久亚洲综合精品蜜桃| 理论片午午伦夜理片在线播放| 国产精品中文有码| 97香蕉超级碰碰久久免费软件| 蜜桃av免费看| 精品视频91| 色一区在线观看| 日本特级黄色大片| 亚洲色图另类小说| 精品亚洲成a人| 国产+成+人+亚洲欧洲| 91成人在线免费视频| 麻豆精品久久| 色综合久久天天| 蜜臀av性久久久久蜜臀av| 少妇性bbb搡bbb爽爽爽欧美| 极品少妇一区二区三区精品视频| 韩国欧美亚洲国产| 麻豆天美蜜桃91| 视频一区在线观看| 欧美本精品男人aⅴ天堂| 中文字幕在线观看第三页| 美女航空一级毛片在线播放| 国产精品视频一二| 国内外成人免费视频| 国产富婆一级全黄大片| 奇米影视7777精品一区二区| 国内自拍欧美激情| 免费在线观看一级片| 精品一区二区三| 亚洲精品suv精品一区二区| 涩涩网站在线看| 亚洲播播91| 精品久久久久久中文字幕| 亚洲一区二区四区| 国产午夜精品一区理论片| 不卡视频在线观看| 99久久综合狠狠综合久久止| 91片黄在线观看喷潮| 久久中文精品| 日本精品视频在线观看| 日本少妇性高潮| 精品999网站| 欧美大尺度在线观看| 久久国产高清视频| 欧美成人milf| 色偷偷偷综合中文字幕;dd| 男女做爰猛烈刺激| 天堂俺去俺来也www久久婷婷| 日韩欧美一区二区在线视频| 免费精品99久久国产综合精品应用| 国产综合色区在线观看| 色综合久久综合| 国产精品视频一区二区三区四区五区| 91在线三级| 亚洲成av人影院| www成人免费| 人人超在线公开视频| 亚洲色图一区二区三区| av电影一区二区三区| 九色porny在线| 国产精品初高中害羞小美女文| 午夜精品一区二区在线观看| 大片免费播放在线视频| 欧美国产一区二区在线观看| 亚洲人体一区| 伦xxxx在线| 一区二区欧美在线观看| 久久在线中文字幕| 国产拍在线视频| 欧美午夜激情在线| 能在线观看的av网站| 51一区二区三区| 欧美日韩高清在线| 韩国三级与黑人| aiai久久| 亚洲男子天堂网| 欧美人妻一区二区三区| 999久久久亚洲| 欧美老女人在线视频| 九九热这里有精品视频| 亚洲欧美日韩精品一区二区 | 在线网址91| 一卡二卡三卡日韩欧美| 缅甸午夜性猛交xxxx| 欧美freesex| 欧美日韩国产高清一区二区 | 中文字幕日韩免费视频| 97在线观看视频免费| 欧美日韩1080p| 欧美中在线观看| 国产又大又黄的视频| 成人白浆超碰人人人人| 相泽南亚洲一区二区在线播放| 黄av在线免费观看| 欧美日韩国产精品| 亚洲欧美aaa| 偷拍亚洲精品| 精品国偷自产在线视频| 日韩美女黄色片| 麻豆高清免费国产一区| 国产福利久久| 69久久精品| 亚洲6080在线| 久久久久久久久久久久久久久国产| 99国产精品免费网站| 中文字幕av日韩| 香蕉视频一区二区| 久久99国产精品成人| 精品欧美一区二区在线观看视频| 最新国产在线观看| 色综合久久天天综合网| 丰满人妻一区二区三区大胸 | 艳母动漫在线观看| 偷拍视频一区二区三区| 精品蜜桃在线看| 国产人与禽zoz0性伦| 国产美女一区| av资源一区二区| 日本高清视频在线播放| 日韩欧美在线中文字幕| 性猛交╳xxx乱大交| 欧美亚洲精品在线| 热99久久精品| 少妇精品高潮欲妇又嫩中文字幕| 自拍视频在线观看一区二区| 国产成人精品视频ⅴa片软件竹菊| 伊人久久影院| 久久精品视频一| 中文在线资源天堂| 久久久久亚洲综合| 中国丰满人妻videoshd| 国产精品网在线观看| 久久99热精品| 国产女人18毛片18精品| 国产精品麻豆视频| 啊啊啊国产视频| 欧美猛男同性videos| 日本精品在线视频 | 一区二区在线免费视频| 在线视频欧美一区| 日韩人妻无码一区二区三区99| 国内精品在线播放| 亚洲一区二区三区午夜| 国产成+人+综合+亚洲欧美| 亚洲桃花岛网站| 国产午夜精品在线| 337p日本欧洲亚洲大胆鲁鲁| 91成人在线精品| 精品无码国产一区二区三区51安| 亚洲私人影院| 国产精品一区二区三区观看| 国产嫩草在线视频| 欧美精品一区二区三区在线播放| 久久久久久久福利| 成人免费毛片a| 亚洲熟妇无码一区二区三区导航| 韩国精品福利一区二区三区| 亚州精品天堂中文字幕| 十九岁完整版在线观看好看云免费| 亚洲国产成人av好男人在线观看| 久久av一区二区三| 亚洲电影在线| 欧美精品成人一区二区在线观看 | 亚洲欧美校园春色| 欧美有码在线观看视频| 国产三级在线观看| 欧美日韩极品在线观看一区| 91视频青青草| 高清不卡一区二区在线| jizzjizz国产精品喷水| 视频一区欧美| 91美女高潮出水| 久久亚洲资源| 亚洲男人的天堂在线| 在线观看免费黄色小视频| 亚洲欧洲中文日韩久久av乱码| 亚洲av毛片在线观看| 影音先锋久久| 日韩高清三级| 综合久草视频| 97av在线视频| 中文字幕日本在线| 日韩精品一区二区三区视频 | 97超级在线观看免费高清完整版电视剧| 国产日产一区二区| 日韩精品视频观看| 在线观看视频中文字幕| 亚洲在线视频网站| 亚洲av无码一区二区二三区| 久久国产精品一区二区| 日韩极品视频在线观看| 国产免费播放一区二区| 亚洲va欧美va在线观看| 天堂av中文在线观看| 日韩中文字幕久久| 污视频网站免费观看| 欧美在线不卡视频| 日产亚洲一区二区三区| 中文欧美字幕免费| 9.1在线观看免费| 免费欧美在线视频| 欧美亚洲精品一区二区| 亚洲最新av| 日本视频一区二区在线观看| 日韩三级久久| 国产精品视频网| 国产精品电影| 久久成人18免费网站| 你懂得在线网址| 欧美成人一区二区三区在线观看| 福利网址在线观看| 亚洲午夜久久久久| 亚洲色偷偷综合亚洲av伊人| 久久女同性恋中文字幕| 国产麻豆剧传媒精品国产| 久久国产精品99久久人人澡| 成人免费无码av| 尤物在线精品| 欧美一级中文字幕| 欧美国产美女| 日韩一区二区电影在线观看| 欧美日韩一区二区三区四区不卡| 成人欧美一区二区三区黑人| 亚洲伦乱视频| 国产97色在线|日韩| 超碰在线最新网址| 欧美精品在线免费播放| 免费网站看v片在线a| 一区二区三区精品99久久| 青青草在线免费视频| 亚洲第一福利网| 亚洲精品福利网站| 欧美一区二区在线视频| 亚洲一卡二卡在线观看| 欧美自拍偷拍午夜视频| 亚洲色成人www永久网站| 天涯成人国产亚洲精品一区av| 一区二区三区免费高清视频 | 久久老司机精品视频| 亚洲色图视频免费播放| 尤物在线免费视频| 亚洲视频香蕉人妖| 视频国产一区二区| 一区免费观看视频| 熟女少妇a性色生活片毛片| 国产日本欧美一区二区| 欧美人与性囗牲恔配| 久久精品一区八戒影视| 久久久久久久久久久久| 国产日韩精品一区| 在线观看免费黄色网址| 国产精品超碰97尤物18| 日本午夜在线观看| 亚洲人亚洲人成电影网站色| 美女的奶胸大爽爽大片| 一区二区在线观看视频在线观看| 久久午夜鲁丝片午夜精品| 午夜视频在线观看一区二区| 日韩成人一区二区三区| 欧美午夜美女看片| 黄色av一区二区| 欧美日韩一区二区三区四区| 中文字幕一区二区三区四区免费看 | 日韩激情中文字幕| 91国产精品视频在线观看| 蜜臀av国产精品久久久久| 国产一级片自拍| 国产成人在线视频网址| 少妇精品无码一区二区三区| 久久综合一区二区| 国产主播av在线| 亚洲黄色片在线观看| 免费毛片一区二区三区| 日本丶国产丶欧美色综合| 一区二区三区播放| 欧美成人r级一区二区三区| 亚洲免费一级片| 亚洲品质视频自拍网| 午夜在线播放| 欧美华人在线视频| 三上悠亚亚洲一区| 91在线播放国产| 台湾色综合娱乐中文网| 亚洲精品一区二区毛豆| 午夜日韩视频| 国产a级片免费观看| 国模娜娜一区二区三区| 中国xxxx性xxxx产国| 国产清纯在线一区二区www| 2025国产精品自拍| 亚洲在线免费播放| 亚洲免费视频二区| 精品99999| 香蕉视频免费在线播放| 欧美黑人国产人伦爽爽爽| 少妇一区视频| av资源站久久亚洲| 色琪琪久久se色| 成年人看的毛片| 六月丁香婷婷久久| 成人免费网站黄| 亚洲欧美一区二区三区极速播放 | 亚洲激情视频小说| 一区二区在线观看免费| 波多野结衣日韩| 亚洲大尺度美女在线| 麻豆传媒在线免费看| 国产www精品| 久久动漫网址| 欧美少妇一区二区三区| 日本亚洲视频在线| 国产精品无码网站| 亚洲一二三级电影| 99久久精品无免国产免费| 一区二区在线免费视频| 欧美激情20| 国产精品yjizz| 亚洲蜜桃视频| 国产精品视频分类| 国产日韩欧美制服另类| 国产超碰人人爽人人做人人爱| 欧美成人三级在线| 麻豆网站在线免费观看| 国产精品露脸av在线| 久久最新网址| 99精品人妻少妇一区二区| 懂色av一区二区在线播放| 日本黄色片免费观看| 欧美日韩一区二区欧美激情| 极品白浆推特女神在线观看| 欧美重口另类videos人妖| 天美av一区二区三区久久| 黄色一级视频片| 99精品欧美一区二区三区小说| 精品少妇久久久久久888优播| 欧美一级片在线| 中文在线观看免费| 成人黄色生活片| 天天做天天爱天天爽综合网| 高清一区在线观看| 亚洲国产高清在线观看视频| 看黄色一级大片| 亚洲一品av免费观看| 国产精品粉嫩| 欧洲一区二区在线观看| 日韩精品午夜视频| 无码人妻aⅴ一区二区三区69岛| 色综合色综合色综合 | www欧美日韩| 久久亚洲资源中文字| 中文字幕中文字幕99 | 国产中文欧美精品| 国产精品成人av| 欧美性猛交xxxx乱大交91| 亚洲欧美另类久久久精品| 99精品视频免费看| 欧美大片在线影院| 麻豆精品av| 男女午夜激情视频| 亚洲国产成人午夜在线一区| 中文字幕视频在线播放| 日韩亚洲精品电影| 日韩中文字幕视频网| 国产美女主播在线| 久久综合给合久久狠狠狠97色69| 无码人妻aⅴ一区二区三区有奶水| 亚洲一级一级97网| www.欧美| 人妻夜夜添夜夜无码av| 久久久噜噜噜久噜久久综合| 一区二区自拍偷拍| 久久91精品国产91久久跳| 全国精品免费看| 亚洲老女人av| 亚洲综合久久久久| 久热av在线| 91精品久久久久久蜜桃| 99国内精品| 正在播放国产对白害羞| 精品少妇一区二区三区在线视频| 麻豆成全视频免费观看在线看| 日产精品高清视频免费| 国产精品一区免费在线观看| 五月婷婷开心网| 日韩在线资源网| 日韩激情啪啪| 九色porny自拍| 亚洲1区2区3区4区| 97超碰国产一区二区三区| 风间由美久久久| 日本欧美一区二区三区乱码| 亚洲一区二区91| 在线精品91av| 精品一区二区男人吃奶| 无尽裸体动漫2d在线观看|