vue el-pagination分页查询封装的示例代码

 更新时间:2023年06月29日 10:36:35   作者:请叫我欧皇i  
本文主要介绍了vue el-pagination分页查询封装的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

需求:因为需要用到表单查询的地方太多了,所以为了避免每个页面都写分页组件,直接封装好调用就完事了,简简单单

1.创建Pigination.vue公用组件

<template>
  <div :class="{'hidden':hidden}" class="pagination-container">
    <el-pagination
      :background="background"
      :current-page.sync="currentPage"
      :page-size.sync="pageSize"
      :layout="layout"
      :page-sizes="pageSizes"
      :total="total"
      v-bind="$attrs"
      @size-change="handleSizeChange"
      @current-change="handleCurrentChange"
    ></el-pagination>
  </div>
</template>
<script>
export default {
  name: 'Pagination',
  props: {
    total: {
      required: true,
      type: Number
    },
    // 当前页数
    page: {
      type: Number,
      default: 1
    },
    // 限制,一页多多少行
    limit: {
      type: Number,
      default: 20
    },
    // 分页
    pageSizes: {
      type: Array,
      default() {
        return [10, 20, 30, 50, 100]
      }
    },
    layout: {
      type: String,
      default: 'total, sizes, prev, pager, next, jumper'
    },
    background: {
      type: Boolean,
      default: true
    },
    autoScroll: {
      type: Boolean,
      default: true
    },
    hidden: {
      type: Boolean,
      default: false
    }
  },
  computed: {
    // 当前页数
    currentPage: {
      get() {
        return this.page;
      },
      set(val) {
        this.$emit('update:page', val);
      }
    },
    pageSize: {
      get() {
        return this.limit;
      },
      set(val) {
        this.$emit('update:limit', val);
      }
    }
  },
  methods: {
    handleSizeChange(val) {
      this.$emit('pagination', { page: this.currentPage, size: val });
      // if (this.autoScroll) {
      //   scrollTo(0, 800);
      // }
    },
    handleCurrentChange(val) {
      this.$emit('pagination', { page: val, size: this.pageSize });
      // if (this.autoScroll) {
      //   scrollTo(0, 800);
      // }
    }
  }
}
</script>
<style scoped>
.pagination-container {
  background: #fff;
  padding-top: 10px;
}
.pagination-container.hidden {
  display: none;
}
</style>

2.需要使用分页组件的页面调用

<template>
    <div class="content-box">
        <div class="container">
            <p>主体页面 2 - 2</p>
            <div class="table-container">
                <el-table
                    ref="Table2"
                    :data="list"
                    style="width: 100%;"
                    show-overflow-tooltip="true"
                    @selection-change="handleSelectionChange"
                    border
                >
                    <el-table-column type="selection" align="center"></el-table-column>
                    <el-table-column label="操作" width="120" align="center" fixed="right"> </el-table-column>
                </el-table>
            </div>
            <!-- 分页组件 -->
            <Pagination :total="total" :page.sync="listQuery.pageNum" :limit.sync="listQuery.pageSize" @pagination="getList"></Pagination>
        </div>
    </div>
</template>
<script>
import Pagination from '@/components/common/Pagination';
import { testApi } from '@/api/test';
const defaultListQuery = {
    pageNum: 1,//给后端的数据,可以根据后端需要更改
    pageSize: 10,
    keyword: ''
};
export default {
    data() {
        return {
            listQuery: Object.assign({}, defaultListQuery),//浅拷贝,引用数据类型相互影响
            list: [],
            total: 0,
            listLoading: true,
            selectedList: []
        };
    },
    components: {
      // 注册分页
        Pagination
    },
    created() {
        this.getList();
    },
    methods: {
        getList() {
            // 获取数据列表
            this.listLoading = true;
            testApi(this.listQuery).then(res => {
                this.listLoading = false;
                this.list = res.data.list;
                this.total = res.data.total;
            });
        },
        handleSelectionChange(val) {
            // 批量选择行数
            this.selectedList = val;
        }
    }
};
</script>

3.结果

到此这篇关于vue el-pagination分页查询封装的文章就介绍到这了,更多相关vue el-pagination分页查询封装内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue2从数据变化到视图变化之nextTick使用详解

    vue2从数据变化到视图变化之nextTick使用详解

    这篇文章主要为大家介绍了vue2从数据变化到视图变化之nextTick使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • elementUI的table表格改变数据不更新问题解决

    elementUI的table表格改变数据不更新问题解决

    最近在做vue的项目时发现了一个问题,今天就来解决一下,本文主要介绍了elementUI的table表格改变数据不更新问题解决,感兴趣的可以了解一下
    2022-02-02
  • vue-cli开发时,关于ajax跨域的解决方法(推荐)

    vue-cli开发时,关于ajax跨域的解决方法(推荐)

    下面小编就为大家分享一篇vue-cli开发时,关于ajax跨域的解决方法(推荐),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-02-02
  • Vue如何下载本地静态资源static文件夹

    Vue如何下载本地静态资源static文件夹

    这篇文章主要介绍了Vue如何下载本地静态资源static文件夹,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-09-09
  • vue3自定义插件的作用场景及使用示例详解

    vue3自定义插件的作用场景及使用示例详解

    这篇文章主要为大家介绍了vue3自定义插件的作用场景及使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • vue+xlsx实现表格的导入导出功能

    vue+xlsx实现表格的导入导出功能

    这篇文章主要介绍了vue+xlsx实现表格的导入导出功能,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2023-11-11
  • vue中get方法\post方法如何传递数组参数详解

    vue中get方法\post方法如何传递数组参数详解

    在前后端交互的时候,有时候需要通过get或者delete传递一个数组给后台,下面下面这篇文章主要给大家介绍了关于vue中get方法\post方法如何传递数组参数,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-03-03
  • Vue.Js中的$watch()方法总结

    Vue.Js中的$watch()方法总结

    这篇文章主要给大家介绍了在Vue.Js中的$watch()方法的相关资料,文中通过示例代码介绍的非常详细,对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。
    2017-03-03
  • 一文教会你vue中使用async和await

    一文教会你vue中使用async和await

    async和await作为异步函数,语法很简单,就是在函数前面加上async 关键字,来表示它是异步的,下面这篇文章主要给大家介绍了如何通过一文教会你vue中使用async和await的相关资料,需要的朋友可以参考下
    2022-10-10
  • vue商城中商品“筛选器”功能的实现代码

    vue商城中商品“筛选器”功能的实现代码

    这篇文章主要介绍了vue商城中商品“筛选器”功能的实现,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-07-07

最新评论