EasyUI带选择框的DataGrid实现点击行"不选中或取消选中"的解决方法。

 1 var IsCheckFlag = true; //标示是否是勾选复选框选中行的,true - 是 , false - 否
 2 $("#dg").datagrid({
 3     rownumbers:true,
 4     url: ‘LeadsData.ashx?o=list‘,
 5     method:‘get‘,
 6     fit: true,
 7     striped:true,
 8     pagination: true,
 9     fitColumns: true,
10     checkOnSelect: false,
11     selectOnCheck: true,
12     pageSize: 15,//每页显示的记录条数,默认为10
13     pageList: [15, 30, 45],//可以设置每页记录条数的列表
14     onLoadSuccess: function (data) {
15         AddTipForStar();
16     },
17     onClickCell: function (rowIndex, field, value) {
18         IsCheckFlag = false;
19     },
20     onSelect: function (rowIndex, rowData) {
21         if (!IsCheckFlag) {
22             IsCheckFlag = true;
23             $("#dg").datagrid("unselectRow", rowIndex);
24         }
25     },
26     onUnselect: function (rowIndex, rowData) {
27         if (!IsCheckFlag) {
28             IsCheckFlag = true;
29             $("#dg").datagrid("selectRow", rowIndex);
30         }
31     }
32 });

主要代码就是粗体的部分。

解决思路为,用一个标识变量来保存是否点击了单元格,如果点击了单元格则此操作不是通过复选框操作的,标识设为false。在选中和取消选中事件中判断操作来源,即IsCheckFlag的值。如果为false,选中操作执行取消选中,取消选中操作执行选中。执行之前默认把标识值设为默认值,如果是复选框操作,是不触发 onClickCell 事件的,也就是标识值会是true。

需要注意的就是

 

IsCheckFlag = true;

$("#dg").datagrid("unselectRow", rowIndex);

 

这两句的先后顺序。

如果把 IsCheckFlag = true放在下面,会形成类似死循环的情况。因为 $("#dg").datagrid("unselectRow", rowIndex); 这个事件会直接触发 onUnselect事件,而 IsCheckFlag = true; 没有执行。依次执行便会成为死循环。

时间: 2024-08-07 00:12:01

EasyUI带选择框的DataGrid实现点击行"不选中或取消选中"的解决方法。的相关文章

EasyUI带选择框的DataGrid实现点击行"不选中或取消选中"的解决方法

var IsCheckFlag = true; //标示是否是勾选复选框选中行的,true - 是 , false - 否  $("#dg").datagrid({      rownumbers:true,      url: 'LeadsData.ashx?o=list',      method:'get',      fit: true,      striped:true,      pagination: true,      fitColumns: true,     c

js 设置多个复选框选中和取消选中

// 设置选中 function setCheckboxClick(obj) { if(obj == null) { $.messager.alert('警告', "请选择要设置选中的项!",'warning'); } // alert(obj.value); var authorityId = obj.value; $.ajax({ type: 'post', url: 'getAuthorityByAuthorityId.action', data: {"authorit

JS 设置复选框的选中与取消选中

// 设置选中 function setCheckboxClick(obj) { if(obj == null) { $.messager.alert('警告', "请选择要设置选中的项!",'warning'); } // alert(obj.value); var authorityId = obj.value; $.ajax({ type: 'post', url: 'getAuthorityByAuthorityId.action', data: {"authorit

web前端html实例-点击相文字选中和取消选中checkbox复选框

checkbox复选框大家应该不会陌生,点击此元素可以实现选中或者取消效果. 下面介绍一种更为人性化的措施,点击指定相关内容即可以实现选中和取消选中效果. 代码实例如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="author" content="http://www.softwhy.com/" />

微信小程序的按下抬起事件,下拉选择框的事件及点击确定的方法函数,获取时间的方法,省市区的方法。

抬起按下的事件: 抬起事件: bind:touchstart="nanOne"   把这条属性放到标签里就可以了 在JS中 nanOne: function () { this.setData({ nvimg: '../img/nvOne.png', }) }, 按下事件: bind:touchend="nanTwo" 把这条属性放到标签里就可以了 在JS中 nanTwo: function () { this.setData({ nvimg: '../img/nv

jQuery EasyUI动态添加控件或者ajax加载页面后不能自动渲染问题的解决方法

转自:http://www.cnblogs.com/sunjie9606/archive/2012/09/13/2683636.html 现象: AJAX返回的html无法做到自动渲染为EasyUI的样式.比如:class="easyui-layout" 等 处理方法: 在html片段加载完毕后使用 Js代码 $.parser.parse(context) 即可重新渲染. 实现原理: 首先附上jquery.parser.js的源码 Js代码 (function($){ $.parser

datagrid 禁止点击行

var s = $("#dg").datagrid('getPanel');            var rows = s.find('tr.datagrid-row');            var rows1 = s.find('tr.datagrid-row td[field!=ck]');            rows1.unbind('click').bind('click', function(e) {                return false;    

input复选框选中与取消选中

原文地址:https://blog.51cto.com/13701875/2424757

js中,表单中的选择框学习与使用总结

选择框脚本 选择框是通过<select>和<option>元素来创建.下面从对选择框的几个操作,来学习,总结Js中操作选择框的方法 一.选择选项 (1)只允许选择一项的选择框,访问选项中的最简单方式,就是使用选择框的selectIndex属性. selectedIndex 属性可设置或返回下拉列表中被选选项的索引号.设置selectedIndex会导致取消以前的所有选项并选择指定的那一项,而读取selectedIndex则只会返回选中项第一项的索引值.注意:若允许多重选择,则仅会返