亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue分頁器實現(xiàn)原理詳解

 更新時間:2019年06月28日 15:09:15   作者:昔有木如蓋  
這篇文章主要為大家詳細(xì)介紹了Vue分頁器實現(xiàn)原理,編寫了分頁器組件,具有一定的參考價值,感興趣的小伙伴們可以參考一下

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

網(wǎng)上搜的分頁器大多是jQuery實現(xiàn)的,而且也不太完善,于是自己寫了個分頁器組件,以后再用也不慌,直接復(fù)制過去就ok,下面說說具體實現(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>

分頁器組件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')]">上一頁</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')]">下一頁</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>

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

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

需求:每頁顯示四條新聞

原理:

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

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

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

因為我們的json數(shù)據(jù)就寫了六個,故這樣計算得到的長度就是2(數(shù)據(jù)長度大于4處理得到的數(shù)據(jù)就是2,小于等于4得到的數(shù)值為1),以此類推,將這個數(shù)據(jù)傳入分頁器作為頁碼
在分頁器page組件中利用pros接收父級傳來的處理過后的長度,得到需要展示的分頁器頁碼長度,再把此長度傳到分頁器組件,v-for循環(huán)生成頁碼

3、利用v-if實現(xiàn)頁面任意展示某一段json的數(shù)據(jù),比如我有6條數(shù)據(jù),一頁只需要展示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)初始展示第一頁數(shù)據(jù)嘛

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

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

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

5、還差一點功能是上一頁和下一頁的點擊事件,這個類似點擊頁碼,不同的是點擊頁碼傳遞的數(shù)據(jù)是當(dāng)前頁碼數(shù)字,而點擊上或下一頁,是讓父組件接收指令,因為當(dāng)前的newListPageIndex受到分頁器頁碼的控制,所以只需要操作newListPageIndex令其- -或者++即可,要注意的是第一頁時肯定不能點上一頁了,尾頁不能點下一頁,所以,newListPageIndex令其–(起碼要大于1對吧,2-1=1最小退到第一頁哈)或者++(要小于數(shù)據(jù)的總長度)要寫在if語句里面

if (this.newListPageIndex < this.newListLength) {
  this.newListPageIndex ++
 }
if (this.equipmentListPageIndex > 1) {
  this.newListPageIndex --
 }

6、最后就是頁碼與上頁下頁style顏色顯示的問題,這里設(shè)置是處于當(dāng)前頁碼狀態(tài)時,當(dāng)前頁碼處于是灰色不能點擊,其它頁碼是黑色可點擊。處于第一頁時上一頁灰色不可點擊而下一頁的樣式反之,處于末頁下一頁灰色不可點擊而上一頁的樣式反之
處理思路是,利用三元表達(dá)式來判斷。當(dāng)頁碼通過v-for遍歷,因為當(dāng)前展示區(qū)域控制數(shù)據(jù)的是newListPageIndex(起始加載默認(rèn)為1),這時只要讓頁碼下標(biāo)index+1(因為下標(biāo)從零開始,而長度從1開始)與newListPageIndex相等的那個頁碼塊為灰色不可點擊而其它的頁碼為黑色可點擊即可。計算思路如下:

v-for="(item, index) in newListLength" :key="index" :class="[(newListPageIndex == index+1) ? 'gray-color':'black-color']"

上一頁下一頁以及頁碼都是通過newListPageIndex相聯(lián)系的,所以當(dāng)我點擊頁碼或者上一頁下一頁他們的樣式顏色都會相互影響改變,實現(xiàn)思路大抵如上了。

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

相關(guān)文章

  • 在原生HTML中使用VUE的保姆級教學(xué)

    在原生HTML中使用VUE的保姆級教學(xué)

    Vue.js是一種流行的JavaScript框架,用于構(gòu)建交互式的Web應(yīng)用程序,這篇文章主要給大家介紹了關(guān)于在原生HTML中使用VUE的保姆級教學(xué),需要的朋友可以參考下
    2023-10-10
  • Vue中.vue文件比main.js先執(zhí)行的問題及解決

    Vue中.vue文件比main.js先執(zhí)行的問題及解決

    這篇文章主要介紹了Vue中.vue文件比main.js先執(zhí)行的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • vueJs函數(shù)readonly與shallowReadonly使用對比詳解

    vueJs函數(shù)readonly與shallowReadonly使用對比詳解

    這篇文章主要為大家介紹了vueJs函數(shù)readonly與shallowReadonly使用對比詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • Vue項目結(jié)合Vue-layer實現(xiàn)彈框式編輯功能(實例代碼)

    Vue項目結(jié)合Vue-layer實現(xiàn)彈框式編輯功能(實例代碼)

    這篇文章主要介紹了Vue項目中結(jié)合Vue-layer實現(xiàn)彈框式編輯功能,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-03-03
  • vue中的過濾器實例代碼詳解

    vue中的過濾器實例代碼詳解

    這篇文章主要介紹了vue中的過濾器,本文通過文字實例代碼相結(jié)合的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-06-06
  • Vue?+?Axios?請求接口方法與傳參方式詳解

    Vue?+?Axios?請求接口方法與傳參方式詳解

    使用Vue的腳手架搭建的前端項目,通常都使用Axios封裝的接口請求,項目中引入的方式不做多介紹,本文主要介紹接口調(diào)用與不同形式的傳參方法。對Vue?+?Axios?請求接口方法與傳參問題感興趣的朋友一起看看吧
    2021-12-12
  • VUE中的無限循環(huán)代碼解析

    VUE中的無限循環(huán)代碼解析

    本文通過實例代碼給大家介紹了vue中的無限循環(huán),代碼簡單易懂,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2017-09-09
  • Vue項目打包優(yōu)化實踐指南(推薦!)

    Vue項目打包優(yōu)化實踐指南(推薦!)

    如果引入的庫眾多,那么vendor.js文件體積將會相當(dāng)?shù)拇?影響首開的體驗,這篇文章主要給大家介紹了關(guān)于Vue項目打包優(yōu)化實踐的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • vue全局組件與局部組件使用方法詳解

    vue全局組件與局部組件使用方法詳解

    這篇文章主要為大家詳細(xì)介紹了vue全局組件與局部組件的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • Vue常見面試題整理【值得收藏】

    Vue常見面試題整理【值得收藏】

    本文是小編給大家收藏整理的Vue常見面試題,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-09-09

最新評論