我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

今天小编给大家分享一下如何使用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" class="lazy" data-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 class="lazy" data-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) {  let st = (curPageIndex - 1) * eachPageSize; let end = st + eachPageSize; return dataArr.slice(st, end);}export function getTotalCommentCount(url = '', params = null, isSync = true) {  return dataArr.length;}export function getTotalPageCount(url = '', params = null, isSync = true, eachPageSize = 7) {  return Math.floor((dataArr.length + eachPageSize -1 ) / eachPageSize);}

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

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

如何使用FrontPage制作网页

今天就跟大家聊聊有关如何使用FrontPage制作网页,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。  如今似乎整个世界都在因特网上跳动不停, 而你却坐失良机。 每个人都有自己的网页
2023-06-08

Flex 中如何使用DataGrid组件实现分页

Flex 中如何使用DataGrid组件实现分页,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Flex DataGrid组件的分页与排序当Flex DataGrid组件中的
2023-06-17

如何使用FrontPage制作一个网页

这篇文章给大家介绍如何使用FrontPage制作一个网页,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1、网页及其组成通过浏览器在WWW上所看到的每一幅画面都是一个网页(Web Page),如图1-1所示。图1-1网页
2023-06-08

如何使用Vue代码实现一个分页组件

本篇内容主要讲解“如何使用Vue代码实现一个分页组件”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用Vue代码实现一个分页组件”吧!组件部分代码:Vue.component(zpagena
2023-07-04

laypage分页控件如何使用

Laypage是一个基于jQuery的分页控件,可以用于网页中的数据分页展示。以下是使用Laypage分页控件的步骤:1. 引入Laypage的相关文件。在HTML文件中,需要引入jquery.js和laypage.js文件。可以从Layp
2023-08-17

bootstrap分页插件如何使用

要使用Bootstrap分页插件,您需要遵循以下步骤:1. 引入Bootstrap的CSS和JavaScript文件。在您的HTML文件的``标签中添加以下代码:```html```2. 在您的HTML文件中创建一个包含分页的元素。例如,您
2023-08-24

Vue分页组件如何封装

今天小编给大家分享一下Vue分页组件如何封装的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。效果如图话不多说,直接上代码
2023-07-02

Dreamweaver中如何使用插件制作网页漂浮广告

这篇文章将为大家详细讲解有关Dreamweaver中如何使用插件制作网页漂浮广告,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。先在 Dreamweaver 插入一个图层 然后将广告图片放在图层里面 最后,
2023-06-08

如何用html制作网页

HTML是网页设计领域中最为基础和重要的语言之一。它是一种标记语言,可以让开发者创建出结构良好、样式统一、容易维护的网站。要制作一个好看而且有用的网站,需要掌握以下几个步骤:1. 建立文件结构在开始编写HTML之前,需要先建立文件夹和文件。建议将HTML文件保存在独立的目录中,以便后续的编写和修改。还可以使用代码编辑器来帮助编写HTML文件。例如,Visual Studio C
2023-05-14

如何使用Photoshop制作网页线框图

这篇文章主要介绍“如何使用Photoshop制作网页线框图”,在日常操作中,相信很多人在如何使用Photoshop制作网页线框图问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用Photoshop制作网页
2023-06-08

MyBatis分页插件PageHelper如何使用

本篇内容介绍了“MyBatis分页插件PageHelper如何使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!MyBatis使⽤PageH
2023-07-05

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录