Ant Design Vue Pagination分页组件的封装与使用

 更新时间:2023年04月21日 08:44:52   作者:最初都是小白  
这篇文章主要介绍了Ant Design Vue Pagination分页组件的封装与使用方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

Ant Design Vue Pagination分页组件的封装与使用

今天封装一个常用的组件 Pagination 分页

在这里插入图片描述

因为是 Ant Design Vue 的组件,所以必须安装Ant Design Vue才能使用哦~

使用组件(可参考Ant Design Vue 快速上手):

$ npm i --save ant-design-vue

第一步:首先创建一个组件文件Pagination.vue ,完整代码:

<template>
  <div class="mz-antd-pagination">
     <a-pagination
      v-model="current"
      :page-size-options="pageSizeOptions"
      :total="total"
      show-size-changer
      :page-size="pageSize"
      @showSizeChange="onShowSizeChange"
      >
      <template slot="buildOptionText" slot-scope="props">
        <span>{{ props.value }}条/页</span>
      </template>
    </a-pagination>
  </div>
</template>

<script>
export default {
  props: {
    total:{
      type: Number,
      default: 0
    }, 
    pageSizeOptions: {
      type: Array,
      default() {
        return ['10', '20', '30', '40', '50'];
      }
    },
  },
  data() {
    return {
      pageSize: 10,
      current: 1
    };
  },
  mounted() {
  
  },
  methods: {
    onShowSizeChange(current, pageSize) {
      this.pageSize = pageSize;
      this.current = current;
      this.$emit('onShowSizeChange', current, pageSize);
    }
  },
  watch: {
    current(val) {
      this.$emit('onShowSizeChange', val, this.pageSize);
    },
  },
};
</script>

<style lang="scss" scoped>
  .mz-antd-pagination{
    .ant-pagination {
      text-align: right !important;
      margin-top: 20px !important;
    }
  }
</style>

第二步:使用方法

<template>
  <div class="merchandise-news">
     <Breadcrumb :routes='routes'></Breadcrumb>
      <div class="goods-info">
          <div class="table-list">
           <!-- 表格 -->
            <a-table 
            :columns="columns" 
            :data-source="tableData" 
            :locale='{emptyText:"暂无数据"}' 
            :pagination="false"
            :scroll="{ x: 1300 }">
             <!-- <span slot="action" slot-scope="text, record">
                <a-button type="link" @click="goEditPage(record)">编辑</a-button>
              </span> -->
            </a-table>
             <!-- 3.页面使用分页组件 -->
             <Pagination 
              v-model="pagination.current"
              :total="pagination.totalCount"
              show-size-changer
              :page-size="pagination.pageSize"
              @onShowSizeChange="onShowSizeChange"
              ></Pagination>
            
          </div>
      </div>
  </div>    
</template>

<script>
  import Pagination from "@/components/MzAntD/Pagination";  //1. 引入 Pagination.vue 组件,注意路径哦~
   import { getBaseStoreList} from "@/api/storeSmart/baseInfo"
   export default {
    data() {
      return {
        //表格数据:
        columns: [
        {
          title:'序号', 
          customRender: (text, record, index) => `${index + 1}`
        },
        {
          title: '品牌',
          dataIndex: 'brand',
          key: 'brand',
          ellipsis: true,
        }
        {
          title: '状态',
          dataIndex: 'statsName',
          key: 'statsName',
          ellipsis: true,
        },
        {
          title: '操作',
          key: 'action',
          scopedSlots: { customRender: 'action' },
        }
      ],
      // pageSizeOptions: ['10', '20', '30', '40', '50'],    //自定义分页
      pagination:{ //分页数据
        current : 1,
        pageSize: 10,
        totalCount:500
      },
    

      }
    },
    components:{
     Pagination    //2. 在components中定义Pagination
    }, 
    mounted(){
      this.getStoreList()
    },
    methods:{
      // 获取列表
      async getStoreList(){
        let param = {
          pageNo:this.pagination.current,
          pageSize: this.pagination.pageSize
        };
        let res = await getBaseStoreList(param);
         let list = res.data.result.list  //列表数据
        this.tableData = list
        this.pagination.totalCount = res.data.result.totalCount  //表格长度
      },
      // 分页改变时调用组件里的方法
      onShowSizeChange(current, pageSize) {
        console.log(current, pageSize);
        this.pagination.current = current
        this.pagination.pageSize = pageSize;
        //改变完 重新渲染数据
        this.getStoreList()
      },
    }
  }    
</script>

<style scoped lang="scss">

</style>

设置ant design vue中的 pagination的最大分页数

Ant Design Vue 中的 pagination 组件有一个 pageSize 属性,用于设置每页显示的数据条数。

同时,还有一个 total 属性,用于设置数据总条数。通过计算可以算出分页数,从而实现设置最大分页数的目的。

代码示例:

<a-pagination
  :total="total"
  :pageSize="pageSize"
  @change="handlePageChange"
/>
 
<script>
export default {
  data() {
    return {
      total: 100,
      pageSiz

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 解决vue组件props传值对象获取不到的问题

    解决vue组件props传值对象获取不到的问题

    这篇文章主要介绍了vue组件props传值,对象获取不到的问题,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-06-06
  • vue项目使用axios封装request请求的过程

    vue项目使用axios封装request请求的过程

    这篇文章主要介绍了vue项目使用axios封装request请求,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-04-04
  • Vue项目中引入外部文件的方法(css、js、less)

    Vue项目中引入外部文件的方法(css、js、less)

    本篇文章主要介绍了Vue项目中引入外部文件的方法(css、js、less),非常具有实用价值,需要的朋友可以参考下
    2017-07-07
  • vue3前端实现微信支付详细步骤

    vue3前端实现微信支付详细步骤

    这篇文章主要给大家介绍了vue3前端实现微信支付的详细步骤,随着移动端的普及和互联网购买需求的增加,微信支付在电商领域中发挥着越来越重要的作用,文中给出了详细的代码示例,需要的朋友可以参考下
    2023-11-11
  • Vue-cli框架实现计时器应用

    Vue-cli框架实现计时器应用

    这篇文章主要为大家详细介绍了Vue-cli框架实现计时器应用,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • vue3实现图片缩放拖拽功能的示例代码

    vue3实现图片缩放拖拽功能的示例代码

    v3-drag-zoom 是基于 vue3 开发的一个缩放拖拽组件,方便开发者快速实现缩放拖拽功能,效果类似地图的缩放与拖拽,本文给大家介绍了vue3如何快速实现图片缩放拖拽功能,感兴趣的朋友可以参考下
    2024-04-04
  • 详解vue 计算属性与方法跟侦听器区别(面试考点)

    详解vue 计算属性与方法跟侦听器区别(面试考点)

    这篇文章主要介绍了详解vue 计算属性与方法跟侦听器区别(面试考点),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • vue生成token并保存到本地存储中

    vue生成token并保存到本地存储中

    这篇文章主要介绍了vue生成token并保存到本地存储中,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-07-07
  • vue3 el-select懒加载以及自定义指令方式

    vue3 el-select懒加载以及自定义指令方式

    这篇文章主要介绍了vue3 el-select懒加载以及自定义指令方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-04-04
  • vue导入.md文件的步骤(markdown转HTML)

    vue导入.md文件的步骤(markdown转HTML)

    这篇文章主要介绍了vue导入.md文件的步骤(markdown转HTML),帮助大家更好的理解和使用vue框架,感兴趣的朋友可以了解下
    2020-12-12

最新评论