数通互联化工云平台
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

121 lines
2.4 KiB

<template>
<div :class="'pagination ' + { hidden: hidden }">
<el-pagination
v-model:current-page="currentPage"
v-model:page-size="pagesize"
:background="background"
:layout="layout"
:page-sizes="pagesizes"
:total="total"
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
/>
</div>
</template>
<script setup lang="ts">
import { computed, PropType } from "vue";
import { scrollTo } from "@/utils/scroll-to";
const props = defineProps({
total: {
required: true,
type: Number as PropType<number>,
default: 0,
},
page: {
type: Number,
default: 1,
},
limit: {
type: Number,
default: 20,
},
pagesizes: {
type: Array as PropType<number[]>,
default() {
return [10, 20, 30, 50];
},
},
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,
},
});
const emit = defineEmits(["pagination"]);
const currentPage = useVModel(props, "page", emit);
const pagesize = useVModel(props, "limit", emit);
function handleSizeChange(val: number) {
emit("pagination", { page: currentPage, limit: val });
if (props.autoScroll) {
scrollTo(0, 800);
}
}
function handleCurrentChange(val: number) {
currentPage.value = val;
emit("pagination", { page: val, limit: props.limit });
if (props.autoScroll) {
scrollTo(0, 800);
}
}
</script>
<style lang="scss">
.pagination{
position: relative;
.el-pagination.is-background{
justify-content: flex-end;
.el-pagination__total{
position: absolute;
left: 0;
float: left;
margin-left: 0!important;
}
.btn-prev, .btn-next, .el-pager li{
background-color: #fff;
border: solid 1px #d9d9d9;
color: #666;
font-weight: normal;
}
.el-pager li:not(.disabled).is-active,
.el-pager li:not(.disabled):hover,
.btn-prev:not(.disabled):hover,
.btn-next:not(.disabled):hover{
color: $menuHover;
border-color: $menuHover;
background-color: #fff;
}
.btn-prev:disabled, .btn-next:disabled{
color: #c0c4cc;
background-color: #fff;
border-color: #c0c4cc;
}
}
}
</style>
<style lang="scss" scoped>
.pagination {
padding: 12px;
&.hidden {
display: none;
}
}
</style>