我是靠谱客的博主 勤奋小松鼠,最近开发中收集的这篇文章主要介绍vue分页器得封装以及使用方法,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

效果图:
在这里插入图片描述

子组件

<template>
  <div class="pageination_align"> 
   <div class="pageination" v-if="pageinationTotal">
       <div @click="pageUp(0)" class="pagination_page" :class="startDisabled?'disabled':''">首页</div>
        <div @click="pageUp(1)" class="pagination_page" :class="startDisabled?'disabled':''">上一页</div>
        <div class="pagination_page" :class="item==pageinationCurrentPage?'pagination_page_active':''" 
             v-for="item in pageinationLength" @click="jump(item)">
            {{item}}
        </div>
        <div @click="pageDown(1)" class="pagination_page" :class="endDisabled?'disabled':''">下一页</div>
        <div @click="pageDown(0)" class="pagination_page pagination_page_right" :class="endDisabled?'disabled':''">
            尾页
        </div>
    </div> 
  </div>
</template>
  <script>
export default {
  name: "Pagination",
  props: ["total", "size", "page", "changge", "isUrl"],
  data() {
    return {
      pageinationTotal: this.total, //总条目数
      pageinationSize: this.size ? this.size : 10, //每页显示条目个数
      pageinationLength: [],
      pageinationCurrentPage: this.page ? this.page : 1, //当前页数默认1
      pageinationPage: 0, //可分页数
      startDisabled: true, //是否可以点击首页上一页
      endDisabled: true, //是否可以点击尾页下一页
      pageChangge: this.changge, //修改方法
      pageIsUrl: this.isUrl ? true : false, //是否开启修改url
    };
  },
  methods: {
    jump(item) {
      this.pageinationCurrentPage = item;
      this.pagers();
      this.pageChangge(this.pageinationCurrentPage);
    }, //跳转页码
    pagers() {
      //可分页数
      this.pageinationPage = Math.ceil(
        this.pageinationTotal / this.pageinationSize
      );
      //url修改
      if (this.pageIsUrl) {
        this.$router.replace({
          path: this.$route.path,
          query: {
            page: this.pageinationCurrentPage,
          },
        });
      }
      //是否可以点击上一页首页
      this.startDisabled = this.pageinationCurrentPage != 1 ? false : true;
      //是否可以点击下一页尾页

      this.endDisabled =
        this.pageinationCurrentPage != this.pageinationPage ? false : true;
      if (this.pageinationPage == 0) this.endDisabled = true;
      //重置
      this.pageinationLength = [];
      //开始页码1
      let start =
        this.pageinationCurrentPage - 4 > 1
          ? this.pageinationCurrentPage - 4
          : 1;
      //当前页码减去开始页码得到差
      let interval = this.pageinationCurrentPage - start;
      //最多9个页码,总页码减去interval 得到end要显示的数量+
      let end =
        9 - interval < this.pageinationPage
          ? 9 - interval
          : this.pageinationPage;
      //最末页码减开始页码小于8
      if (end - start != 8) {
        //最末页码加上与不足9页的数量,数量不得大于总页数
        end =
          end + (8 - (end - start)) < this.pageinationPage
            ? end + (8 - (end - start))
            : this.pageinationPage;
        //最末页码加上但是还不够9页,进行开始页码追加,开始页码不得小于1
        if (end - start != 8) {
          start = end - 8 > 1 ? end - 8 : 1;
        }
      }
      for (let i = start; i <= end; i++) {
        this.pageinationLength.push(i);
      }
    }, //计算分页显示的数字
    pageUp(state) {
      if (this.startDisabled) return;
      if (this.pageinationCurrentPage - 1 != 0 && state == 1) {
        this.jump(this.pageinationCurrentPage - 1);
      } else {
        this.jump(1);
      }
    }, //上一页跟首页 state=1是上一页 state=0是首页
    pageDown(state) {
      if (this.endDisabled) return;
      if (
        this.pageinationCurrentPage + 1 != this.pageinationPage &&
        state == 1
      ) {
        this.jump(this.pageinationCurrentPage + 1);
      } else {
        this.jump(this.pageinationPage);
      }
    }, // state=1是下一页 state=0是尾页
    pageCurrentChange() {
      this.pageChangge(this.pageinationCurrentPage);
      this.pagers();
    },
  },
  created() {
    this.pageCurrentChange();
  },
  watch: {
    total: function (val, oldVal) {
      this.pageinationTotal = val;
      this.pagers();
    },
    page: function (val, oldVal) {
      this.pageinationCurrentPage = val;
      this.pagers();
    },
  },
};
</script>
<style lang="scss" scoped>
        .pageination_align {
            text-align: center
        }

        .pageination {
            color: #48576a;
            font-size: 12px;
            display: inline-block;
            user-select: none;
        }

        .pagination_page {
            padding: 0 4px;
            border: 1px solid #d1dbe5;
            border-right: 0;
            background: #fff;
            font-size: 13px;
            min-width: 28px;
            height: 28px;
            line-height: 28px;
            cursor: pointer;
            box-sizing: border-box;
            text-align: center;
            float: left;
        }

        .pagination_page_right {
            border-right: 1px solid #d1dbe5;
        }

        .pagination_page:hover {
            color: #20a0ff;
        }

        .disabled {
            color: #e4e4e4 !important;
            background-color: #fff;
            cursor: not-allowed;
        }

        .pagination_page_active {
            border-color: #20a0ff;
            background-color: #20a0ff;
            color: #fff !important;;
            cursor: default;
        }
 </style>

父组件中得使用
template:

   <Pagination
      :total="Total"
      :size="model.size"
      :page="model.page"
      :changge="pageFn"
    ></Pagination>

data数据:

 model: {
        size: 10, //每页显示条目个数不传默认10
        page: 1, //当前页码
      },

methods:

 methods:{
   //页码切换执行方法
   pageFn(val){
          this.model.page=val;//val就是当切换页码时变化之后的当前页码数
          console.log(val);
          //  在这可以调用获取总数据的方法,目的就是让页码与数据响应起来,Total就是获取总数据的条数
       }
   }

代码源于改编,欢迎采纳

最后

以上就是勤奋小松鼠为你收集整理的vue分页器得封装以及使用方法的全部内容,希望文章能够帮你解决vue分页器得封装以及使用方法所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(55)

评论列表共有 0 条评论

立即
投稿
返回
顶部