0

0

layui table跨页选择数据 layui表格如何保留跨分页的复选框状态

畫卷琴夢

畫卷琴夢

发布时间:2026-03-17 16:32:32

|

302人浏览过

|

来源于php中文网

原创

layui.table 默认不记住跨页选中状态,因其翻页时重绘DOM、丢弃原选中标识,且未绑定主键维护已选集合;需用id缓存selectedIds,并在done回调中同步row.LAY_CHECKED与checkbox状态。

为什么 layui.table 默认不记住跨页选中状态

因为 layui 的 table.render 每次翻页都会重新请求数据、重绘 dom,res.data 是全新数组,之前勾选的 obj.lay_checked 和 checkbox 的 checked 属性全被丢弃。它不自动维护“已选集合”,也不把选中状态和数据主键绑定 —— 所以你下一页再回来,就只剩空 checkboxes。

核心做法:用主键缓存选中项,done 里手动回填

关键不是操作 DOM,而是让 layui 内部识别哪些行该被“认为已选”。必须同时做两件事:
① 把用户点过的数据(建议用唯一字段如 id)存进一个全局数组,比如 selectedIds = []
② 在 done 回调里,遍历当前页 res.data,对每个匹配 id 的项设置 row.LAY_CHECKED = true,并触发真实 checkbox 的勾选。

常见错误现象:
• 只改了 DOM 的 checked 属性,但没设 row.LAY_CHECKEDtable.checkStatus('xxx').data 拿不到选中数据
• 用 indexLAY_TABLE_INDEX 当标识 → 翻页后 index 重排,完全错位
• 没在 done 里处理全选框状态 → 表头 checkbox 显示未全选,哪怕当前页所有数据都已在 selectedIds

table.on('checkbox(xxx)') 事件里该写什么

监听复选框变化时,只负责增删 selectedIds,别碰 DOM 或 table 实例。layui 已经帮你处理了单行勾选/取消的视觉更新,你只需同步业务状态:

  • 勾选时:if (obj.checked) { selectedIds.push(obj.data.id); }
  • 取消时:if (!obj.checked) { selectedIds = selectedIds.filter(id => id !== obj.data.id); }
  • 全选/反选时:obj.type === 'all' 分支里,用 res.data.map(d => d.id) 批量操作,别用 obj.data(它只含当前页)

注意:不要在 checkbox 监听里调 table.checkStatus 或尝试重绘表格 —— 这会引发重复渲染或状态冲突。

全选框状态怎么自动同步

全选框是否打钩,取决于当前页所有数据是否都在 selectedIds 中。这个判断必须放在 done 里做,不能靠监听事件推导:

优设AI导航
优设AI导航

优设网旗下专业全面的AI工具导航

下载

const currPageIds = res.data.map(d => d.id);<br>const isAllCurrSelected = currPageIds.every(id => selectedIds.includes(id));<br>$('.layui-table th[data-field="0"] input[type="checkbox"]').prop('checked', isAllCurrSelected).next().toggleClass('layui-form-checked', isAllCurrSelected);

容易踩的坑:
• 忘记用 toggleClass 或手动加 class → 表面勾了,但样式没变
• 把 data-field="0" 写成其他值 → 如果你第一列不是 checkbox(比如加了 fixed 或 toolbar),得按实际列序号调整
• 在非 done 场景里强行读取当前页数据 → table.cache 未必及时更新,不可靠

最麻烦的其实是去重和性能:如果用户反复翻页又全选,selectedIds 可能堆积大量重复 id。上线前务必加一层 [...new Set(selectedIds)] 去重,尤其当后端返回数据没严格保证主键唯一时。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

847

2023.08.22

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

565

2023.09.20

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

448

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

606

2023.08.10

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

931

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

32

2025.12.06

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

77

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

41

2025.11.16

抖漫入口地址合集
抖漫入口地址合集

本专题整合了抖漫入口地址相关合集,阅读专题下面的文章了解更多详细地址。

3

2026.03.17

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号