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分页查询封装内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
最新评论