解决JQuery全选/反选第二次失效的问题


Posted in jQuery onOctober 11, 2017

最近在项目中,遇到一个问题,测试全选/反选功能时,第一次对母框进行选中/非选中时,能同步子框的全选/反选状态,之后再点击母框,子框就没反应了。

原代码大致结构关键如下:

function selectAll(obj){
    $('input[name="xxx[]"]').attr("checked",obj.checked);
}

<input type="checkbox" id="mother" name="mother" onclick="selectAll(this);"/>全选

<input type="checkbox" id="son1" name="xxx[]" />子框<input type="checkbox" id="son2" name="xxx[]" />子框<input type="checkbox" id="son3" name="xxx[]" />子框<input type="checkbox" id="son4" name="xxx[]" />子框

步骤一:尝试正面刚一波:

function selectAll(obj){
   if(obj.checked) {
    $('input[name="xxx[]"]').attr("checked", true);
   } else {
    $('input[name="xxx[]"]').removeAttr("checked");
   }
}

卒-----完全没有效果,弃之。

步骤二:快速上网搜索一番,发现这个问题比较常见,在遇到过这个问题的人里,我应该排在千里之外了。点开几个看了,基本都是说用prop替代attr便能解决,奈何如下:

解决JQuery全选/反选第二次失效的问题

然而项目上用的版本低于1.6并被告知最好不要更改版本,同弃之。

步骤三:无可奈何,JQuery弃之...尝试改用原生js写法,代码如下:

function selectAll(obj){
 var xxx = document.getElementsByName("xxx[]");
  if(obj.checked) {
   for(var i = 0;i < xxx.length;i++) {
    xxx[i].checked = true;
   }
  } else {
   for(var i = 0;i < xxx.length;i++) {
    xxx[i].checked = false;
   }
  }
}

测试一下,顺利解决。其实也算是个小问题,不过给了我一些启示,不能局限在一个框里,多换个角度思考问题,往往能更好地去解决问题。

以上这篇解决JQuery全选/反选第二次失效的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

jQuery 相关文章推荐
jQuery中animate()的使用方法及解决$(”body“).animate({“scrollTop”:top})不被Firefox支持的问题
Apr 04 jQuery
详谈jQuery.load()和Jsp的include的区别
Apr 12 jQuery
JS jQuery使用正则表达式去空字符的简单实现代码
May 20 jQuery
jquery ztree实现右键收藏功能
Nov 20 jQuery
jquery实现左右轮播切换效果
Jan 01 jQuery
基于jquery.page.js实现分页效果
Jan 01 jQuery
jQuery zTree搜索-关键字查询 递归无限层功能实现代码
Jan 25 jQuery
jQuery实现带右侧索引功能的通讯录示例【附源码下载】
Apr 17 jQuery
基于jQuery实现无缝轮播与左右点击效果
May 13 jQuery
jQuery实现弹幕特效
Nov 29 jQuery
jQuery HTML设置内容和属性操作实例分析
May 20 jQuery
jQuery-App输入框实现实时搜索
Nov 19 jQuery
jQuery实现的form转json经典示例
Oct 10 #jQuery
认识jQuery的Promise的具体使用方法
Oct 10 #jQuery
jQuery实现获取table中鼠标click点击位置行号与列号的方法
Oct 09 #jQuery
jQuery插件artDialog.js使用与关闭方法示例
Oct 09 #jQuery
jQuery实现html双向绑定功能示例
Oct 09 #jQuery
jqueryUI tab标签页代码分享
Oct 09 #jQuery
jQuery ajax调用webservice注意事项
Oct 08 #jQuery
You might like
PHP初学入门
2006/11/19 PHP
遭遇php的in_array低性能问题
2013/09/17 PHP
php计算数组相同值出现次数的代码(array_count_values)
2015/01/20 PHP
PHP安全下载文件的方法
2016/04/07 PHP
Nigma vs Alliance BO5 第三场2.14
2021/03/10 DOTA
javascript 日期常用的方法
2009/11/11 Javascript
jquery对表单操作2
2011/04/06 Javascript
通过Javascript将数据导出到外部Excel文档的函数代码
2012/06/15 Javascript
JQuery 操作/获取table具体代码
2013/06/13 Javascript
JS设置获取cookies的方法
2014/01/26 Javascript
textarea焦点的用法实现获取焦点清空失去焦点提示效果
2014/05/19 Javascript
node.js中的fs.fchmodSync方法使用说明
2014/12/16 Javascript
jQuery实现不断闪烁文字的方法
2015/05/15 Javascript
对Angular.js Controller如何进行单元测试
2016/10/25 Javascript
不使用 JS 匿名函数理由
2017/11/17 Javascript
vue实现跨域的方法分析
2019/05/21 Javascript
解决layui 表单元素radio不显示渲染的问题
2019/09/04 Javascript
vue 实现element-ui中的加载中状态
2020/11/11 Javascript
vue中axios封装使用的完整教程
2021/03/03 Vue.js
[01:06:25]Secret vs Liquid 2018国际邀请赛淘汰赛BO3 第一场 8.25
2018/08/29 DOTA
[01:06:12]VP vs NIP 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
python结合API实现即时天气信息
2016/01/19 Python
对pycharm代码整体左移和右移缩进快捷键的介绍
2018/07/16 Python
Ubuntu18.04下python版本完美切换的解决方法
2019/06/14 Python
python GUI库图形界面开发之PyQt5日期时间控件QDateTimeEdit详细使用方法与实例
2020/02/27 Python
澳洲CFL商城:CHEMIST FOR LESS(中文)
2021/02/28 全球购物
化学实验员岗位职责
2013/12/28 职场文书
大学校庆策划书
2014/01/31 职场文书
创业计划书之孕婴生活馆
2019/11/11 职场文书
JS不要再到处使用绝对等于运算符了
2021/04/30 Javascript
详细分析PHP7与PHP5区别
2021/06/26 PHP
Python快速实现一键抠图功能的全过程
2021/06/29 Python
为什么MySQL选择Repeatable Read作为默认隔离级别
2021/07/26 MySQL
javascript遍历对象的五种方式实例代码
2021/10/24 Javascript
springboot layui hutool Excel导入的实现
2022/03/31 Java/Android
【海涛DOTA】D-cup邀请赛NV.cn vs DT.Love
2022/04/01 DOTA