更新记录:
调用方式:
<template>
<paging-query :pager="pager" @query="getItemList"/>
template>
<script>
import PagingQuery from '@/components/PagingQuery';
export default {
components: {
PagingQuery,
},
data() {
pager: {
count: 0,
page: 1,
rows: 15,
},
},
methods: {
// 查询请求
getItemList() {}
},
script>
paging-query.vue
<template>
<form class="mod-paging fn-clear" @submit.prevent>
<el-pagination
small
class="fn-right"
layout="total, sizes, prev, pager, next, jumper"
background
:pager-count="7"
:total="pager[props.total]"
:current-page.sync="pager[props.page]"
:page-size="pager[props.rows]"
:page-sizes="pageSizes"
@size-change="onChangeSize"
@current-change="onChangePage"
>el-pagination>
<el-button icon="el-icon-refresh" @click="$emit('query')">刷新el-button>
form>
template>
<script>
import config from '@/config/app.config';
export default {
name: 'Paging',
// 设置绑定参数
model: {
prop: 'pager',
event: 'setPager',
},
props: {
pager: {
type: Object,
required: true,
},
refresh: {
type: Boolean,
},
pageSizes: {
type: Array,
default: () => ([10, 15, 30, 50]),
},
props: {
type: Object,
required: false,
default: () => ({
// 第几页
page: 'page',
// 显示条数
rows: 'rows',
// 总记录条数
total: 'count',
}),
},
},
computed: {
total() {
return this.pager[this.props.total] || 0;
},
// 检测获取到的数据是否为空
isEmptyList() {
return (
Math.ceil(this.pager[this.props.total] / this.pager[this.props.rows])
< this.pager[this.props.page]
);
},
},
watch: {
total() {
// 存在记录但未获取到数据时, 重新请求
if (this.pager[this.props.page] > 1 && this.isEmptyList) {
this.$emit(
'setPager',
Object.assign(this.pager, {
[this.props.page]: this.pager[this.props.page] - 1,
})
);
this.$nextTick(() => {
this.$emit('query');
});
}
},
},
methods: {
// 每页条数
onChangeSize(rows) {
const temp = {
[this.props.rows]: rows,
// 当显示条数小于或等于总条数时,重置页数
[this.props.page]: rows <= this.total ? 1 : this.pager[this.props.page],
};
this.$emit('setPager', Object.assign(this.pager, temp));
// 触发父组件查询请求
this.$nextTick(() => {
this.$emit('query');
});
},
// 翻页
onChangePage(page) {
this.$emit(
'setPager',
Object.assign(this.pager, { [this.props.page]: page })
);
this.$emit('query');
},
},
};
script>