vue3封装el-pagination分页组件

1、效果如图:
在这里插入图片描述
2、分页组件代码:

<template><div class="paging"><el-config-provider :locale="zhCn"><el-paginationv-model:current-page="page.currentPage"v-model:page-size="page.pageSize":background="page.background":layout="page.layout":total="page.total"@size-change="page.handleSizeChange"@current-change="page.handleCurrentChange"/></el-config-provider></div>
</template><script setup>
import { ElConfigProvider } from 'element-plus'
import zhCn from 'element-plus/es/locale/lang/zh-cn';
zhCn.el.pagination.goto = "到第"
const props = defineProps({total: {required: true,type: Number,default: 300},// 当前页数currentPage: {type: Number,default: 1},// 分页pageSize: {type: Array,default: () => {return [10, 20, 30, 50, 100]}},limit: {type: Number,default: 10},layout: {type: String,default: 'total, sizes, prev, pager, next, jumper'},background: {type: Boolean,default: () => {return true},},
});
const emit = defineEmits();
const currentPage = computed({get() {return props.currentPage},set(val) {emit('update:currentPage', val)}
})const pageSize = computed({get() {return props.limit},set(val) {emit('update:limit', val)}
})
const page  = reactive({background:props.background,currentPage:props.currentPage,pageSize:props.pageSize[0],layout:props.layout,total:props.total,handleSizeChange:(val)=>{console.log(`${val} items per page`)emit('handleSizeChange', val);},handleCurrentChange:(val)=>{console.log(`current page: ${val}`)emit('handleCurrentChange', val);}
});
</script><style lang="scss" scoped>
</style>

3、使用代码:

**结构:**
<template>
<Paging:current-page="page.currentPage":page-size="page.pageSize":background="page.background":layout="page.layout":total="page.total":limit="page.limit"@handleSizeChange="page.handleSizeChange"@handleCurrentChange="page.handleCurrentChange"></Paging>
</template>**js:**
<script setup>
import Paging from "@/components/paging";//引入分页组件
const page = reactive({layout:'prev, pager, next, jumper',currentPage:1,limit:10,total:300,handleSizeChange:(val)=>{page.pageSize = val},handleCurrentChange:(val)=>{page.currentPage = val}
})
</script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/439258.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JVM系列——垃圾收集器

对象存活判断 引用计数法 在对象中添加一个引用计数器&#xff0c;每当有一个地方引用它时&#xff0c;计数器值就加一&#xff1b;当引用失效时&#xff0c;计数器值就减一&#xff1b;任何时刻计数器为零的对象就是不可能再被使用的。 可达性分析算法 通过一系列称为“GC …

C语言系列-整数在内存中的存储大小端字节序

&#x1f308;个人主页: 会编程的果子君 ​&#x1f4ab;个人格言:“成为自己未来的主人~” 目录 整数在内存中的存储 大小端字节序和字节序判断 什么是大小端 为什么会有大小端 练习 整数在内存中的存储 在讲解操作符的时候&#xff0c;我们就讲过了下面的内容 整数的2…

Aigtek电压放大器选购技巧和方法有哪些

电压放大器设计是电子工程领域的重要一环&#xff0c;它在各种电子设备和通信系统中扮演着关键角色。在设计一个高性能的电压放大器时&#xff0c;需要考虑以下几个重要的设计要求。 增益要求&#xff1a;电压放大器的主要功能就是将输入的电压信号放大到所需的输出电压。因此&…

统一监控、统一运维,贵阳新世界学校上线智和信通运维方案

贵阳新世界学校是贵阳一中教育发展联盟校、教育部中国教师发展基金会校本建设项目全国重点实验学校、美国加州大学欧文分校在中国的第一所生源基地学校、中美“千校携手”项目学校、中美高中生交流基地学校、首批贵州省校本研修示范学校。截至2022年&#xff0c;学校建设以万兆…

格子表单GRID-FORM | 嵌套子表单与自定义脚本交互

格子表单/GRID-FORM已在Github 开源&#xff0c;如能帮到您麻烦给个星&#x1f91d; GRID-FORM 系列文章 基于 VUE3 可视化低代码表单设计器嵌套表单与自定义脚本交互 新版本功能 &#x1f389; 不觉间&#xff0c;GRID-FORM 已经开源一年&#xff08;2023年1月29日首次提交…

PeakCAN连接到WSL2 Debian

操作步骤 按照以下步骤进行操作&#xff1a; 在Windows下安装PeakCAN驱动并安装&#xff0c;地址是https://www.peak-system.com/PCAN-USB.199.0.html?&L1 在Windows下安装usbipd&#xff0c;地址是https://github.com/dorssel/usbipd-win/releases&#xff0c;最新版是…

sqli-labs-master less-1 详解

目录 关于MySQL的一些常识 information_schema 常用的函数 sqli-labs-master less-1 分析PHP源码 测试 关于MySQL的一些常识 information_schema information_schema 是 MySQL 数据库中的一个元数据&#xff08;metadata&#xff09;数据库&#xff0c;它包含…

计数排序(六)——计数排序及排序总结

目录 一.前言 二.归并小补充 三.计数排序 操作步骤&#xff1a; 代码部分&#xff1a; 四.稳定性的概念&#xff1a; 五.排序大总结&#xff1a; ​六.结语 一.前言 我们已经进入排序的尾篇了&#xff0c;本篇主要讲述计数排序以及汇总各类排序的特点。码字不易&#x…

[Tcpdump] 网络抓包工具使用教程

往期回顾 海思 tcpdump 移植开发详解海思 tcpdump 移植开发详解 前言 上一节&#xff0c;我们已经讲解了在海思平台如何基于静态库生成 tcpdump 工具&#xff0c;本节将作为上一节的拓展内容。 一、tcpdump 简介 「 tcpdump 」是一款强大的网络抓包工具&#xff0c;它基于…

国标GB/T 28181详解:GB/T28181基本注册流程和注销流程

目 录 一、基本要求 二、注册流程 三、注销流程 四、产品说明 五、参考 一、基本要求 根据《GB/T 28181-2022》第9章关于注册和注销的描述&#xff0c;GB28181的注册和注销应满足下面这些要求&#xff1a; SIP 客户端网关、SIP 设备、联网系统等 SIP 代理…

【command】使用nr简化npm run命令

参考文章 添加 alias nrnpm run通过alias启动命令可以帮助我们节省运行项目输入命令的时间 $ cd ~ $ vim .bash_profile $ source ~/.bashrc

一进一出模拟量信号隔离变送器

一进一出模拟量信号隔离变送器 捷晟达科技推出一进一出模拟量信号隔离变送器 深圳捷晟达科技推出一款具有隔离,放大,转换保护功能的一进一出的小型隔离变送器设备,该设备可以把模拟量(4-20mA/0-10V等)标准信号转换用户需要的信号,该产品具有抗EMC干扰,可以有效的保护后级设备安…