当前位置: 首页 > news >正文

vxe-table 如何实现分页勾选复选框功能,分页后还能支持多选的选中状态

vxe-table 如何实现分页勾选复选框功能,分页后还能支持多选的选中状态,要实现这个功能,有多种方式

https://vxetable.cn

  1. 可以使用一个变量来记录已选的数据,在分页时重新赋值选中状态。
  2. 使用内置的选中状态记忆保留功能,可以直接使用,无需再额外写代码

分页多选保留状态

当使用数据分页与复选框多页选中时,可以通过 checkbox-config.reserve 启用,将不会自动清除勾选数据,如果清除,可以调用 clearCheckboxReserve 方法手动清除已保留的选中数据

table_checkbox_reserve

<template><div><vxe-button status="success" @click="getSelectEvent">获取已选</vxe-button><vxe-grid ref="gridRef" v-bind="gridOptions" v-on="gridEvents"></vxe-grid></div>
</template><script setup>
import { ref, reactive } from 'vue'
import { VxeUI } from 'vxe-table'const gridRef = ref()const allList = [{ id: 10001, name: 'Test1', nickname: 'T1', role: 'Develop', sex: 'Man', age: 28, address: 'Shenzhen' },{ id: 10002, name: 'Test2', nickname: 'T2', role: 'Test', sex: 'Women', age: 22, address: 'Guangzhou' },{ id: 10003, name: 'Test3', nickname: 'T3', role: 'PM', sex: 'Man', age: 32, address: 'Shanghai' },{ id: 10004, name: 'Test4', nickname: 'T4', role: 'Designer', sex: 'Women', age: 23, address: 'test abc' },{ id: 10005, name: 'Test5', nickname: 'T5', role: 'Develop', sex: 'Women', age: 30, address: 'Shanghai' },{ id: 10006, name: 'Test6', nickname: 'T6', role: 'Designer', sex: 'Women', age: 21, address: 'Shenzhen' },{ id: 10007, name: 'Test7', nickname: 'T7', role: 'Test', sex: 'Man', age: 29, address: 'Shenzhen' },{ id: 10008, name: 'Test8', nickname: 'T8', role: 'Develop', sex: 'Man', age: 35, address: 'test abc' },{ id: 10009, name: 'Test9', nickname: 'T9', role: 'Develop', sex: 'Man', age: 35, address: 'Shenzhen' },{ id: 100010, name: 'Test10', nickname: 'T10', role: 'Develop', sex: 'Man', age: 35, address: 'Guangzhou' },{ id: 100011, name: 'Test11', nickname: 'T11', role: 'Develop', sex: 'Man', age: 49, address: 'Guangzhou' },{ id: 100012, name: 'Test12', nickname: 'T12', role: 'Develop', sex: 'Women', age: 45, address: 'Shanghai' },{ id: 100013, name: 'Test13', nickname: 'T13', role: 'Test', sex: 'Women', age: 35, address: 'Guangzhou' },{ id: 100014, name: 'Test14', nickname: 'T14', role: 'Test', sex: 'Man', age: 29, address: 'Shanghai' },{ id: 100015, name: 'Test15', nickname: 'T15', role: 'Develop', sex: 'Man', age: 39, address: 'Guangzhou' },{ id: 100016, name: 'Test16', nickname: 'T16', role: 'Test', sex: 'Women', age: 35, address: 'Guangzhou' },{ id: 100017, name: 'Test17', nickname: 'T17', role: 'Test', sex: 'Man', age: 39, address: 'Shanghai' },{ id: 100018, name: 'Test18', nickname: 'T18', role: 'Develop', sex: 'Man', age: 44, address: 'Guangzhou' },{ id: 100019, name: 'Test19', nickname: 'T19', role: 'Develop', sex: 'Man', age: 39, address: 'Guangzhou' },{ id: 100020, name: 'Test20', nickname: 'T20', role: 'Test', sex: 'Women', age: 35, address: 'Guangzhou' },{ id: 100021, name: 'Test21', nickname: 'T21', role: 'Test', sex: 'Man', age: 39, address: 'Shanghai' },{ id: 100022, name: 'Test22', nickname: 'T22', role: 'Develop', sex: 'Man', age: 44, address: 'Guangzhou' }
]const pagerVO = reactive({total: 0,currentPage: 1,pageSize: 10
})const gridOptions = reactive({showOverflow: true,border: true,loading: false,height: 500,rowConfig: {keyField: 'id'},checkboxConfig: {reserve: true},pagerConfig: pagerVO,columns: [{ type: 'checkbox', width: 60 },{ field: 'name', title: 'Name', minWidth: 160 },{ field: 'email', title: 'Email', minWidth: 160 },{ field: 'nickname', title: 'Nickname', minWidth: 160 },{ field: 'age', title: 'Age', width: 100 },{ field: 'role', title: 'Role', minWidth: 160 },{ field: 'amount', title: 'Amount', width: 140 },{ field: 'updateDate', title: 'Update Date', visible: false },{ field: 'createDate', title: 'Create Date', visible: false }],data: []
})// 模拟前端分页
const handlePageData = () => {gridOptions.loading = truesetTimeout(() => {const { pageSize, currentPage } = pagerVOpagerVO.total = allList.lengthgridOptions.data = allList.slice((currentPage - 1) * pageSize, currentPage * pageSize)gridOptions.loading = false}, 100)
}const gridEvents = {pageChange ({ pageSize, currentPage }) {pagerVO.currentPage = currentPagepagerVO.pageSize = pageSizehandlePageData()}
}const getSelectEvent = () => {const $grid = gridRef.valueif ($grid) {const selectRecords = $grid.getCheckboxRecords()const selectReserveRecords = $grid.getCheckboxReserveRecords()VxeUI.modal.message({content: `总共勾选: ${selectRecords.length + selectReserveRecords.length} 条,当前页勾选:${selectRecords.length} 条,已保留勾选:${selectReserveRecords.length} 条`,status: 'success'})}
}handlePageData()
</script>

同时在其他分页中显示为半选状态

以上已经实现了分页状态保留功能,但是产品如果说还要在分页的同时,如果已选了其他页数据,当前页要显示半选状态,那么就可以通过以下来实现。

启用保留选中状态后默认是每页独立状态显示,可以通过 checkbox-config.showReserveStatus 启用,当存在保留记录时,则未勾选当前页数据也会显示未半选状态

table_checkbox_show_reserve_status

<template><div><vxe-button status="success" @click="getSelectEvent">获取已选</vxe-button><vxe-grid ref="gridRef" v-bind="gridOptions" v-on="gridEvents"></vxe-grid></div>
</template><script setup>
import { ref, reactive } from 'vue'
import { VxeUI } from 'vxe-table'const gridRef = ref()const allList = [{ id: 10001, name: 'Test1', nickname: 'T1', role: 'Develop', sex: 'Man', age: 28, address: 'Shenzhen' },{ id: 10002, name: 'Test2', nickname: 'T2', role: 'Test', sex: 'Women', age: 22, address: 'Guangzhou' },{ id: 10003, name: 'Test3', nickname: 'T3', role: 'PM', sex: 'Man', age: 32, address: 'Shanghai' },{ id: 10004, name: 'Test4', nickname: 'T4', role: 'Designer', sex: 'Women', age: 23, address: 'test abc' },{ id: 10005, name: 'Test5', nickname: 'T5', role: 'Develop', sex: 'Women', age: 30, address: 'Shanghai' },{ id: 10006, name: 'Test6', nickname: 'T6', role: 'Designer', sex: 'Women', age: 21, address: 'Shenzhen' },{ id: 10007, name: 'Test7', nickname: 'T7', role: 'Test', sex: 'Man', age: 29, address: 'Shenzhen' },{ id: 10008, name: 'Test8', nickname: 'T8', role: 'Develop', sex: 'Man', age: 35, address: 'test abc' },{ id: 10009, name: 'Test9', nickname: 'T9', role: 'Develop', sex: 'Man', age: 35, address: 'Shenzhen' },{ id: 100010, name: 'Test10', nickname: 'T10', role: 'Develop', sex: 'Man', age: 35, address: 'Guangzhou' },{ id: 100011, name: 'Test11', nickname: 'T11', role: 'Develop', sex: 'Man', age: 49, address: 'Guangzhou' },{ id: 100012, name: 'Test12', nickname: 'T12', role: 'Develop', sex: 'Women', age: 45, address: 'Shanghai' },{ id: 100013, name: 'Test13', nickname: 'T13', role: 'Test', sex: 'Women', age: 35, address: 'Guangzhou' },{ id: 100014, name: 'Test14', nickname: 'T14', role: 'Test', sex: 'Man', age: 29, address: 'Shanghai' },{ id: 100015, name: 'Test15', nickname: 'T15', role: 'Develop', sex: 'Man', age: 39, address: 'Guangzhou' },{ id: 100016, name: 'Test16', nickname: 'T16', role: 'Test', sex: 'Women', age: 35, address: 'Guangzhou' },{ id: 100017, name: 'Test17', nickname: 'T17', role: 'Test', sex: 'Man', age: 39, address: 'Shanghai' },{ id: 100018, name: 'Test18', nickname: 'T18', role: 'Develop', sex: 'Man', age: 44, address: 'Guangzhou' },{ id: 100019, name: 'Test19', nickname: 'T19', role: 'Develop', sex: 'Man', age: 39, address: 'Guangzhou' },{ id: 100020, name: 'Test20', nickname: 'T20', role: 'Test', sex: 'Women', age: 35, address: 'Guangzhou' },{ id: 100021, name: 'Test21', nickname: 'T21', role: 'Test', sex: 'Man', age: 39, address: 'Shanghai' },{ id: 100022, name: 'Test22', nickname: 'T22', role: 'Develop', sex: 'Man', age: 44, address: 'Guangzhou' }
]const pagerVO = reactive({total: 0,currentPage: 1,pageSize: 10
})const gridOptions = reactive({showOverflow: true,border: true,loading: false,height: 500,rowConfig: {keyField: 'id'},checkboxConfig: {reserve: true,showReserveStatus: true},pagerConfig: pagerVO,columns: [{ type: 'checkbox', width: 60 },{ field: 'name', title: 'Name', minWidth: 160 },{ field: 'email', title: 'Email', minWidth: 160 },{ field: 'nickname', title: 'Nickname', minWidth: 160 },{ field: 'age', title: 'Age', width: 100 },{ field: 'role', title: 'Role', minWidth: 160 },{ field: 'amount', title: 'Amount', width: 140 },{ field: 'updateDate', title: 'Update Date', visible: false },{ field: 'createDate', title: 'Create Date', visible: false }],data: []
})// 模拟前端分页
const handlePageData = () => {gridOptions.loading = truesetTimeout(() => {const { pageSize, currentPage } = pagerVOpagerVO.total = allList.lengthgridOptions.data = allList.slice((currentPage - 1) * pageSize, currentPage * pageSize)gridOptions.loading = false}, 100)
}const gridEvents = {pageChange ({ pageSize, currentPage }) {pagerVO.currentPage = currentPagepagerVO.pageSize = pageSizehandlePageData()}
}const getSelectEvent = () => {const $grid = gridRef.valueif ($grid) {const selectRecords = $grid.getCheckboxRecords()const selectReserveRecords = $grid.getCheckboxReserveRecords()VxeUI.modal.message({content: `总共勾选: ${selectRecords.length + selectReserveRecords.length} 条,当前页勾选:${selectRecords.length} 条,已保留勾选:${selectReserveRecords.length} 条`,status: 'success'})}
}handlePageData()
</script>

https://gitee.com/x-extends/vxe-table

http://www.jsqmd.com/news/170906/

相关文章:

  • 2025年靠谱信誉好的资产评估审计机构推荐:售后完善、口碑优选排行榜 - 工业设备
  • Android视频播放器快速集成指南:告别繁琐开发的高效方案
  • Transformer模型详解:结合TensorFlow 2.9实现高效Token生成与训练
  • MediaPipe机器学习示例:零基础快速构建智能应用的终极指南
  • Bazelisk构建管理利器:多版本Bazel智能切换的完整指南
  • Bug修复场景高效解决!MonkeyCode AI自动拆解需求,快速定位修复
  • 自动收板机远程监控运维系统方案
  • Xilem内存管理深度解析:智能指针与生命周期的高级应用
  • 2025年口碑好的咖啡培训场地推荐,认证咖啡培训与咖啡培训定制学校全解析 - 工业品牌热点
  • 2025年狭缝涂布机生产企业推荐:狭缝涂布机公司推荐 - 工业推荐榜
  • MAC OS下载配置java1.8环境,下载配置maven3.6 自用傻瓜式教程
  • HTML Canvas绘图:可视化TensorFlow-v2.9注意力权重分布
  • 2025山东阻燃剂材料企业TOP5权威推荐:万丰科技领跑行业 - 工业推荐榜
  • 计算机Java毕设实战-基于SpringBoot的动物园管理系统的设计与实现 智慧化动物园综合管理平台设计与实现票务管理、收入管理【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 2026年螺杆阀厂家权威推荐榜:精密点胶/导热胶/伺服/耐磨/防腐蚀/硅胶/AB胶/双液/单液/全氟聚醚/氟胶螺杆阀,匠心工艺与高适配性深度解析 - 品牌企业推荐师(官方)
  • 合同管理系统哪家强?行业热门选择与功能解析 - 品牌排行榜
  • 2026年 涂胶机厂家权威推荐榜:ARO/GRACO全自动精密涂胶机,覆盖汽车玻璃/新能源电机/锂电/双组分等应用场景的工业涂胶解决方案 - 品牌企业推荐师(官方)
  • ComfyUI-SeedVR2:AI视频画质修复实战手册,轻松实现专业级视频增强
  • 合同管理系统推荐:企业高效管理的实用工具 - 品牌排行榜
  • SSH代理转发技巧:跨跳板机连接TensorFlow训练节点
  • 通信原理中GMSK调制解调仿真详解
  • VMware虚拟机检测绕过终极指南:实现完美隐身
  • Animate Plus:现代Web动画技术的演进与前瞻
  • ‌Jira/Xray/Zephyr:测试用例与缺陷管理实践‌
  • 无线局域网WLAN组网配置
  • autocannon性能基准测试终极指南:API压力测试与优化实战
  • 2025留学机构评价榜:综合实力与口碑精选解析 - 品牌排行榜
  • CH340驱动安装难题:从设备管理器异常到串口通信畅通的完整解决方案
  • 深度学习开发者必备:TensorFlow-v2.9完整镜像使用手册
  • 比较可靠的留学机构有哪些?行业精选推荐与解析 - 品牌排行榜