温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何使用vue.js制作分页组件

发布时间:2022-10-23 17:24:30 来源:亿速云 阅读:278 作者:iii 栏目:web开发

今天小编给大家分享一下如何使用vue.js制作分页组件的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

首先是index.html

<!DOCTYPE html> <html> <head>  <title>Page</title>  <style type="text/css">   * {    margin: 0;    padding: 0;    font-family: 'Open Sans', Arial, sans-serif;   }   .contianer {    width: 50%;    height: auto;    margin: 20px auto;   }   article {    margin-bottom: 50px;   }  </style> </head> <body>  <div class='contianer'>   <article>    文章内容...   </article>   <div id='main'>    <app></app>     </div>  </div>  <script type="text/javascript" src='bundle.js'></script> </body> </html>

我将 app这个组件放在 <div id='main'></div> 内
通过webpack打包后,入口的js文件是entry.js,用来引入app.vue组件
entry.js

let Vue = require('vue'); import App from './components/app'; let app_vue = new Vue({  el: '#main',  components: {   app: App  } });

接下来看下这个app组件

<style type="text/css" scoped>   </style> <template>  <comment :cur-page-index="curPageIndex" :each-page-size="eachPageSize" :comment-url="commentUrl"    :comment-params="commentParams" :comment-is-sync="commentIsSync">     </comment>  <page :cur-page-index.sync="curPageIndex" :each-page-size="eachPageSize" :page-url="pageUrl"    :page-params="pageParams" :page-is-sync="pageIsSync">  </page> </template>  <script type="text/javascript">  import Comment from './comment';  import Page from './page';  export default {   data () {    return {     curPageIndex: 1,     eachPageSize: 7,    }   },   components: {    comment: Comment,    page: Page   },  } </script>

它有2个子组件,分别是comment.vue和page.vue,通过动态绑定数据,进行父子间组件通信,我是这样认为的,对于 当前在第几页 应当由 page.vue传递给app.vue,所以这里我们使用 双向绑定,其余的如 params, url, isSync,即向后台请求数据的东西以及是否同步或异步操作<当然,这里我还没有测试过后台数据,目前是直接js生成静态数据>。

接下来,看下comment.vue评论组件

<style type="text/css" scoped>  .comt-mask {   opacity: 0.5;  }  .comt-title {     }  .comt-line {   width: 100%;   height: 2px;   background-color: #CCC;   margin: 10px 0;  }  .comt-wrap {     }  .comt-user {   float: left;  }  .comt-img {   width: 34px;   height: 34px;   border-radius: 17px;  }  .comt-context {   margin: 0 0 0 60px;  }  .comt-name {   color: #2B879E;   margin-bottom: 10px;   font-size: 18px;  } </style> <template>  <div v-if="hasComment" :class="{'comt-mask': loading}">   <h4 class='comt-title'>{{ totalCommentCount }} 条评论</h4>   <div class="comt-line"></div>   <div class="comt-wrap" v-for="comment of commentArr">    <div class="comt-user">     <img src='{{ comment.avatar }}' class="comt-img"/>    </div>    <div class="comt-context">     <p class="comt-name">{{ comment.name }}</p>        <p>      {{ comment.context }}     </p>    </div>    <div class="comt-line"></div>   </div>  </div> </template> <script type="text/javascript">  import {getCommentData, getTotalCommentCount} from './getData';  export default {   props: {    curPageIndex: {     type: Number,     default: 1,    },    eachPageSize: {     type: Number,     default: 7,    },    commentUrl: {     type: String,     default: '',    },    commentParams: {     type: Object,     default: null,    },    commentIsSync: {     type: Boolean,     default: true,    },   },   data () {    return {     totalCommentCount: 0,     hasComment: false,     loading: true,       }   },   computed: {    commentArr () {     this.loading = true;     let res = getCommentData(this.commentUrl, this.commentParams, this.commentIsSync, this.curPageIndex, this.eachPageSize);     this.loading = false;     return res;    },   },   created () {    let cnt = getTotalCommentCount(this.commentUrl, this.commentParams);    this.totalCommentCount = cnt;    this.hasComment = cnt > 0;   }  } </script>

这里的 getData.js 将在下面提到,是我们获取数据的位置。
loading: 本意是在跳转页码加载评论时,对于当前评论加载0.5的透明度的遮罩,然后ajax通过它的回调函数来取消遮罩,现在这样就不能实现了,只能强行写下,然而是没有用的..
hasComment: comment组件第一次加载的时候,我们就去请求获得总共的数据长度,如果没有数据,则不显示comment组件布局内容
·curPageIndex·: 通过父组件app传递下来,使用的是props
这些数据,我们都设置一个默认值与类型比较好。
page.vue

<style type="text/css" scoped>  .page {   text-align: center;   margin: 30px;  }  .page-btn {   color: gray;   background-color: white;   border: white;   width: 30px;   height: 30px;   margin: 5px;   font-size: 18px;   outline: none;  }  .page-btn-link {   cursor: Crosshair;  }  .page-btn-active {   border: 1px solid gray;   border-radius: 15px;  } </style> <template>  <div class="page">   <button v-for="pageIndex of pageArr" track-by='$index' :class="{'page-btn': true, 'page-btn-active':     this.curPageIndex === pageIndex, 'page-btn-link': checkNum(pageIndex)}"     @click="clickPage(pageIndex)" >     {{ pageIndex }}   </button>    </div> </template> <script type="text/javascript">  import {getTotalPageCount} from './getData';  export default {   props: {    totalPageCount: {     type: Number,     default: 0,    },    curPageIndex: {     type: Number,     default: 1,    },    eachPageSize: {     type: Number,     default: 7,    },    pageAjcn: {     type: Number,     default: 4,    },    pageUrl: {     type: String,     default: '',    },    pageParams: {     type: Object,     default: null,    },    pageIsSync: {     type: Boolean,     default: true,    }         },   data () {    return {    }   },   computed: {    pageArr () {     let st = 1,      end = this.totalPageCount,      cur = this.curPageIndex,      ajcn = this.pageAjcn,      arr = [],      left = Math.floor(ajcn / 2),      right = ajcn - left;           if (end == 0 || cur == 0) {      return arr;     } else {      console.log(st, end, cur, left, right);      arr.push(st);      console.log(st+1, cur-left);      if (st + 1 < cur - left) {       arr.push('...');      }      for (let i = Math.max(cur - left, st + 1); i <= cur - 1; ++i) {       arr.push(i);      }      if (cur != st) {       arr.push(cur);      }      for (let i = cur + 1; i <= cur + right && i <= end - 1 ; ++i) {       arr.push(i);      }      if (cur + right < end - 1) {       arr.push('...');      }      if (end != cur) {       arr.push(end);      }      return arr;     }     }   },   methods: {    clickPage (curIndex) {     if (Number.isInteger(curIndex)) {      this.curPageIndex = curIndex;     }    },    checkNum (curIndex) {     return Number.isInteger(curIndex);    }      },   created () {    this.totalPageCount = getTotalPageCount(this.pageUrl,  this.pageParams, this.pageIsSync,      this.eachPageSiz);   }  } </script>

主要是个对于 组件事件的运用,=最常见的click事件,以及class与style的绑定,根据 curPageIndex与this.pageIndex来比较,判断是否拥有这个class,通过computed计算属性,来获得 页码数组 因为会根据当前页 有所变化,created的时候 计算出总页码。
最后一个是 目前生成获取静态数据的js文件.

// let data = { //  avatar: '', 头像 //  name: '', 用户名 //  context: '', 评论内容 // } let dataArr = []; function randomStr (len) {  return Math.random().toString(36).substr(len); } function initData () {  for (var i = 0; i<45 ; ++i) {   let _avator = "./resources/" + i%7 + ".jpg";   let _name = randomStr(20);   let _context = randomStr(2);   dataArr.push({    avatar: _avator,    name: _name,    context: _context   });  } } if (!dataArr.length) {  initData(); } export function getCommentData (url = '', params = null, isSync = true, curPageIndex = 1, eachPageSize = 7) {  /* ajax */  let st = (curPageIndex - 1) * eachPageSize;  let end = st + eachPageSize;  return dataArr.slice(st, end); } export function getTotalCommentCount(url = '', params = null, isSync = true) {  /* ajax */  return dataArr.length; } export function getTotalPageCount(url = '', params = null, isSync = true, eachPageSize = 7) {  /* ajax */  return Math.floor((dataArr.length + eachPageSize -1 ) / eachPageSize); }

以上就是“如何使用vue.js制作分页组件”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI