EasyUI DataGrid在updateRow会重新渲染该行,导致绑定的事件失效

因为在更新行数据时,EasyUI DataGrid 会重新渲染该行,导致之前绑定的事件失效。这是因为当您调用 updateRow 方法后,DataGrid 会重新生成该行的 HTML,而原有的事件绑定只作用于旧的 HTML 元素上。

为了解决这个问题,您可以采用事件委托的方式来绑定事件。事件委托是一种在父元素上监听事件的技术,然后根据事件的目标元素来执行相应的操作。由于父元素不会随着子元素的更新而改变,因此这种方法可以确保即使子元素被重新渲染,事件依然能够被触发。

有问题的代码:
 

$('.checkbox-isuse').click(function (e) {console.log('click0')//获取点击复选框当前行的索引var $checkbox = $(this);var ix = $checkbox.closest('tr.datagrid-row').attr('datagrid-row-index');var row = data.rows[ix];var checked = $checkbox.prop("checked");// 获取当前复选框的选中状态var field = $checkbox.attr('data-field'); // 获取对应的字段名console.log(ix, checked, field, row)// 更新对应字段的值$('#gridBox-0').datagrid('updateRow', {index: ix,row: {[field]: checked ? 1 : 0}});e.stopPropagation();
});

使用事件委托的解决方案:

onLoadSuccess: function (data) {// 使用事件委托方式绑定点击事件$('#gridBox-0').datagrid('getPanel').off('click', '.checkbox-isuse').on('click', '.checkbox-isuse', function(e) {var $checkbox = $(this);var index = $checkbox.closest('tr.datagrid-row').attr('datagrid-row-index');var field = $checkbox.attr('data-field'); // 获取对应的字段名var checked = $checkbox.prop('checked'); // 获取当前复选框的选中状态// 更新对应字段的值$('#gridBox-0').datagrid('updateRow', {index: parseInt(index),row: {[field]: checked ? 1 : 0}});// 阻止事件冒泡e.stopPropagation();});
},

在这个示例中,我们使用 $('#gridBox-0').datagrid('getPanel') 来获取 DataGrid 的面板元素,并在这个元素上绑定点击事件。off('click', '.checkbox-isuse') 是为了避免重复绑定事件,每次 onLoadSuccess 被调用时先移除之前的事件绑定。

这种方式可以确保即使行被重新渲染,事件依然能够被正确触发。您应该在 onLoadSuccess 回调中使用这种方式来绑定复选框的点击事件。

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

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

相关文章

FlyClient SPV client轻量化

这篇文章主要是为了构建一种轻客户端的算法。 如果使用SPV 的方式验证交易,每个client上面需要存储非常多的header。使用 proofs of proof-of-work 的方式,使得请客户端仅仅下载少量的区块头就能验证这一条链的安全性,然后再对包含交易的区块…

Linux脚本语言学习

第一章Linux学习方式 1.1.1 Linux中的大小写和英文输入法 在Linux中除了大小写之外,需要关注的就是输入法的中文和英文状态,在使用linux的过程中如果不小心在中文状态下输入中文的空格,或者是在网络上拷贝他人的脚本发现运行后出现错误的信…

华为机试 字符串最后一个单词的长度

本题中,我们是要从键盘输入一个字符串,然后返回这个字符串最后一个单词的长度。所以我们需要scancer类。我们需要注意的是,hasnext()和hasnextline()这两个函数的区别。 import java.util.Scanner;// 注意类名必须为 Main, 不要有任何 pack…

内存函数详解

1. memcpy函数 void * memcpy ( void * destination, const void * source, size_t num ); 1.1 函数的功能,使用与注意事项 1. memcpy函数的作用是内存拷贝,即将source指向的空间中的num个字节拷贝到destination指向的空间中去,然后返回de…

力扣hot---岛屿数量

思路dfs: 首先通过两层for循环遍历每一个点,如果这个点为0或者2(这个2是什么呢?是在遍历该点以及该点连成的这一片区域中,因为通过深度优先搜索,遍历该点就等于遍历这一片区域,遍历这篇区域中的…

玩家至上:竞技游戏设计如何满足现代玩家的需求?

文章目录 一、现代玩家需求分析二、以玩家体验为核心的游戏设计三、个性化与定制化服务四、强化社交互动与社区建设五、持续更新与优化《游戏力:竞技游戏设计实战教程》亮点编辑推荐内容简介目录获取方式 随着科技的飞速发展和游戏产业的不断壮大,现代玩…

通讯协议----USB2.0协议

USB2.0协议 USB总线的信号常见信号数据编解码和位填充 USB设备的检测USB设备的挂起USB传输PacketPacket包种类Data PID作用 TransactionTransfer控制传输(Control Transfers):中断传输(Interrupt Transfers)同步传输(Isochronous Transfers)大容量数据传输(Bulk Transfers)控制…

安装QT时,安装进程(qt.tools.perl)运行期间出现错误

安装QT时,安装进程(qt.tools.perl)运行期间出现错误 解决方法

【MySQL】数据库的操作(1)

【MySQL】数据库的操作(1) 目录 【MySQL】数据库的操作(1)创建数据库数据库的编码集和校验集查看系统默认字符集以及校验规则查看数据库支持的字符集查看数据库支持的字符集校验规则校验规则对数据库的影响数据库的删除 数据库的备…

对象实例、类信息、常量、静态变量分别在运行时数据区的哪个位置?

在Java中,对象实例、类信息、常量、静态变量在运行时数据区的位置如下: 对象实例(Object Instance):对象实例通常存储在堆(Heap)中。堆是用于存储动态分配的对象的内存区域,每个对象…

TypeScript 之 介绍和入门

TypeScript简介 它是由微软开发的自由和开源的编程语言, 属于静态编程语言,在编写的时候会直接检测错误。 它是JavaScript的超集, TypeScript需要通过编译器将其编译生成为JavaScript文件才能运行,因此该语言的运行要比JavaScrip…

06 - 镜像管理之:基础知识

1 了解镜像 Docker镜像是一个特殊的文件系统,除了提供容器运行时所需的程序、库、资源、配置等文件外,还包含了一些为运行时准备的一些配置参数(如匿名卷、环境变量、用户等)。 但注意, 镜像不包含任何动态数据&#…

什么是Linux?

目录 什么是Linux? Linux一般可以做什么? 什么是Linux? Linux是一个开源的类Unix操作系统。它的内核由林纳斯托瓦兹(Linus Torvalds)在1991年首次发布。Linux操作系统遵循自由和开源软件发展模型,意味着…

信呼OA普通用户权限getshell方法

0x01 前言 信呼OA是一款开源的OA系统,面向社会免费提供学习研究使用,采用PHP语言编写,搭建简单方便,在中小企业中具有较大的客户使用量。从公开的资产治理平台中匹配到目前互联中有超过1W的客户使用案例。 信呼OA目前最新的版本是…

【微软技术】介绍

微软技术 微软是一家全球领先的技术公司,创立于1975年,由比尔盖茨和保罗艾伦共同创立,微软开发、制造、许可、支持和销售各种电脑软件、消费电子产品、个人电脑和相关服务。以下将介绍一些微软的关键技术和产品: Windows 操作系统…

SpringSecurity接口权控(权限控制)

最近项目需要做“接口权限”控制&#xff0c;但不需要做RBAC (Role Based Access Control)这种大的业务。于是有下面的方案。 一、项目pom文件 <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artif…

WSL2-在Ubuntu-22.04上安装MySQL(deb包)并配置ODBC

启用 systemd 通过链接启用 systemdhttps://learn.microsoft.com/zh-cn/windows/wsl/systemd#how-to-enable-systemd sudo nano /etc/wsl.conf #在文件中添加如下内容&#xff1a; [boot] systemdtrue #添加后重启WSL wsl.exe --shutdown 否则会出现如下错误&#xff1a;ERRO…

【HTML】HTML基础7.1(无序列表)

目录 标签 属性 效果 注意 标签 <ul> <li>列表里要装的东西</li> <li>列表里要装的东西</li> <li>列表里要装的东西</li> </ul> 属性 type&#xff1a; circle空心圆disc实心圆square方框 效果 circle空心圆效果…

operator-sdk入门(mac)

1. 安装operator-sdk brew install operator-sdk 2. 安装kubebuilder brew install kubebuilder 3.初始化一个operator脚手架 3.1 新建一个文件夹 redis-operator 3.2 执行初始化 operator-sdk init --domain lyl.com --repo github.com 参数介绍 可以通过operator-sdk --…

推荐系统评价指标介绍--CG, DCG, NDCG

基础概念 首先明确CG这一系列指标既可用于打分场景&#xff0c;又可用于点击场景&#xff0c;用于判断模型给出的推荐列表 y ^ \hat{y} y^​和用户打分&#xff08;点击列表&#xff09; r e l rel rel之间的相似性。  基于CG的评价指标的计算 基础流程为&#xff1a; 依据前…