123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- <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 {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, 12, 20, 24, 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", "update:page", "update:limit"]);
- 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" scoped>
- .pagination {
- margin-top: 3rem;
- padding: 1rem;
- color:#474b59;
- &.hidden {
- display: none;
- }
- }
- :deep(.el-input){
- border: 1px solid #dddcdd;
- border-radius: 5px;
- }
- :deep(.el-pagination){
- justify-content: center;
- }
- </style>
|