国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

Vue分頁(yè)器實(shí)現(xiàn)原理詳解

2019-11-19 11:15:05
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

本文為大家講解了Vue分頁(yè)器實(shí)現(xiàn)原理,供大家參考,具體內(nèi)容如下

網(wǎng)上搜的分頁(yè)器大多是jQuery實(shí)現(xiàn)的,而且也不太完善,于是自己寫(xiě)了個(gè)分頁(yè)器組件,以后再用也不慌,直接復(fù)制過(guò)去就ok,下面說(shuō)說(shuō)具體實(shí)現(xiàn)的代碼和原理吧。

新聞組件template:

<template> <div v-if="news"> <div v-for="(item, index) in newList" v-if="(index <= (newListPageIndex * 4)-1) && (index >= (newListPageIndex-1) * 4)" class="new-show-left"> <div class="new-img">  <img :src="item.img" alt=""/> </div> <div class="time">  <span>{{item.time}}</span> </div> <h1>{{item.title}}</h1> <p>{{item.content}}</p> </div> </div></template><script type="text/ecmascript-6"> import page from '@/components/page' import bus from '@/eventBus/eventBus' import {getNew} from '@/getData/getData' export default{ components: { page }, data () { return { newList: '', newList2: '', newListLength: '', newListPageIndex: '1', // 下標(biāo) next: false, previous: false, news: true, title: '' } }, created () { this.$nextTick(() => { this._init_list1() }) bus.$on('current-item', (ev) => { this.$nextTick(() => {  this.currentItem(ev) }) }) bus.$on('next-page', (ev) => { this.$nextTick(() => {  this.nextPage(ev) }) }) bus.$on('previous-page', (ev) => { this.$nextTick(() => {  this.previousPage(ev) }) }) }, methods: { _init_list1 () { getNew().then(res => {  this.newList = res.data.list1  let myObject = res.data.list1  this.newListLength = Object.keys(myObject).length  this.newListLength = Math.ceil((this.newListLength) / 6)  this.pageStyle() }) }, pageStyle () { if (this.newListPageIndex < this.newListLength) {  this.next = true  if (this.newListPageIndex > 1) {  this.previous = true  } else {  this.previous = false  } } else {  this.next = false  if (this.newListPageIndex > 1) {  this.previous = true  } else {  this.previous = false  } } }, currentItem (ev) { this.newListPageIndex = ev window.scrollTo(0, 500) this.pageStyle() }, nextPage () { if (this.newListPageIndex < this.newListLength) {  this.newListPageIndex ++  window.scrollTo(0, 500)  this.pageStyle() } }, previousPage () { if (this.newListPageIndex > 1) {  this.newListPageIndex --  window.scrollTo(0, 500)  this.pageStyle() } } } }</script>

分頁(yè)器組件template:

<template> <ul class="page"> <li>  <img @click="previousPage" :src="[(previous==true ? 'static/images/leftGo-black.png' : 'static/images/leftGo.png')]">  <span @click="previousPage" :class="[(previous==true ? 'black-color' : 'gray-color')]">上一頁(yè)</span> </li> <li >  <span @click="currentItem" v-for="(item, index) in listLength" :class="[(listPageIndex == index+1) ? 'gray-color':'black-color']">{{item}}</span> </li> <li>  <span @click="nextPage" :class="[(next == true ? 'black-color':'gray-color')]">下一頁(yè)</span>  <img @click="nextPage" :src="[(next==true ? 'static/images/rightGo.png' : 'static/images/rightGo-gray.png')]"> </li> </ul></template><script type="text/ecmascript-6"> import bus from '@/eventBus/eventBus' export default{ props: { listLength: '', listPageIndex: '', next: '', previous: '' }, created () {// console.log(this.next) }, methods: { currentItem (ev) { bus.$emit('current-item', ev.target.innerHTML) }, nextPage (ev) { bus.$emit('next-page', ev) }, previousPage (ev) { bus.$emit('previous-page', ev) } } }</script>

一,首先自己寫(xiě)一個(gè)json文件(六條數(shù)據(jù)我就寫(xiě)兩條吧,太長(zhǎng)了),并在新聞組件里使用axios請(qǐng)求這個(gè)json文件:

{ "id": "1", "title": "新聞一", "time": "2017.10", "content": "新聞一的簡(jiǎn)介...", "imgSrc": "static/images/new1.png"},{ "id": "2", "title": "新聞二", "time": "2017.11", "content": "新聞二的簡(jiǎn)介...", "imgSrc": "static/images/new2.png"},...(總歸六條數(shù)據(jù)省略四條不寫(xiě))

需求:每頁(yè)顯示四條新聞

原理:

1、請(qǐng)求接口數(shù)據(jù),生成HTML頁(yè)面(利用axios請(qǐng)求json文件,v-for循環(huán)將數(shù)據(jù)排版)

2、動(dòng)態(tài)生成分頁(yè)器頁(yè)碼(根據(jù)json數(shù)據(jù)長(zhǎng)度):
利用axios請(qǐng)求json文件,需要用到兩個(gè)數(shù)據(jù):一個(gè)是json這段新聞的長(zhǎng)度newListLength,一個(gè)是這段數(shù)據(jù)的自身newtList,對(duì)數(shù)據(jù)長(zhǎng)度的處理方法是:

this.newListLength = Math.ceil((this.newListLength) /4)

因?yàn)槲覀兊膉son數(shù)據(jù)就寫(xiě)了六個(gè),故這樣計(jì)算得到的長(zhǎng)度就是2(數(shù)據(jù)長(zhǎng)度大于4處理得到的數(shù)據(jù)就是2,小于等于4得到的數(shù)值為1),以此類(lèi)推,將這個(gè)數(shù)據(jù)傳入分頁(yè)器作為頁(yè)碼
在分頁(yè)器page組件中利用pros接收父級(jí)傳來(lái)的處理過(guò)后的長(zhǎng)度,得到需要展示的分頁(yè)器頁(yè)碼長(zhǎng)度,再把此長(zhǎng)度傳到分頁(yè)器組件,v-for循環(huán)生成頁(yè)碼

3、利用v-if實(shí)現(xiàn)頁(yè)面任意展示某一段json的數(shù)據(jù),比如我有6條數(shù)據(jù),一頁(yè)只需要展示4條

<div v-for="(item, index) in newList" v-if="(index <= (newListPageIndex * 4)-1) && (index >= (newListPageIndex-1) * 4)">

在新聞組件中令newListPageIndex的默認(rèn)值是1,那么v-if=(0 =< index <= 3)初始展示第一頁(yè)數(shù)據(jù)嘛

4、上面三步實(shí)現(xiàn)了幾個(gè)功能,展示任意一段數(shù)據(jù),分頁(yè)器隨json內(nèi)取的這段數(shù)據(jù)動(dòng)態(tài)生成頁(yè)碼。下面要做聯(lián)動(dòng),分頁(yè)器頁(yè)碼點(diǎn)擊對(duì)應(yīng)展示相應(yīng)區(qū)域的json數(shù)據(jù)。

當(dāng)前點(diǎn)擊頁(yè)碼上的點(diǎn)擊事件是currentItem,利用emit提交當(dāng)前節(jié)點(diǎn),獲取頁(yè)碼數(shù)字,父組件emit提交當(dāng)前節(jié)點(diǎn),獲取頁(yè)碼數(shù)字,父組件on接收這個(gè)頁(yè)碼數(shù)字。

令this.newListPageIndex = ev,這樣就會(huì)引起v-if里面計(jì)算表達(dá)式的改變,如果是點(diǎn)擊的1,那么v-if=”(index <= (newListPageIndex * 4)-1) && (index >= (newListPageIndex-1) * 4)”。計(jì)算結(jié)果是0=< index <=7,即展示json里下標(biāo)為0到3的4條數(shù)據(jù),類(lèi)推,如果點(diǎn)擊的是2,則展示下標(biāo)為4=< index <=7的數(shù)據(jù)。

5、還差一點(diǎn)功能是上一頁(yè)和下一頁(yè)的點(diǎn)擊事件,這個(gè)類(lèi)似點(diǎn)擊頁(yè)碼,不同的是點(diǎn)擊頁(yè)碼傳遞的數(shù)據(jù)是當(dāng)前頁(yè)碼數(shù)字,而點(diǎn)擊上或下一頁(yè),是讓父組件接收指令,因?yàn)楫?dāng)前的newListPageIndex受到分頁(yè)器頁(yè)碼的控制,所以只需要操作newListPageIndex令其- -或者++即可,要注意的是第一頁(yè)時(shí)肯定不能點(diǎn)上一頁(yè)了,尾頁(yè)不能點(diǎn)下一頁(yè),所以,newListPageIndex令其

主站蜘蛛池模板: 庆元县| 洪泽县| 河间市| 海林市| 苗栗县| 清新县| 西青区| 喜德县| 莱西市| 伊吾县| 汝南县| 石景山区| 鲜城| 吕梁市| 赤峰市| 西城区| 惠安县| 安徽省| 太湖县| 和龙市| 长垣县| 安远县| 吴旗县| 新乡县| 涿州市| 牟定县| 汉川市| 凌云县| 嘉祥县| 宜州市| 武川县| 余姚市| 冕宁县| 凤凰县| 彭阳县| 青浦区| 北海市| 简阳市| 司法| 尤溪县| 金山区|