解决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插件HighCharts绘制2D饼图效果示例【附demo源码下载】
Mar 21 jQuery
jQuery插件FusionWidgets实现的Bulb图效果示例【附demo源码下载】
Mar 23 jQuery
jQuery事件_动力节点Java学院整理
Jul 05 jQuery
jQuery基于cookie实现换肤功能实例
Oct 14 jQuery
JS/jQuery实现DIV延时几秒后消失或显示的方法
Feb 12 jQuery
基于jQuery实现无缝轮播与左右点击效果
May 13 jQuery
jQuery实现的监听导航滚动置顶状态功能示例
Jul 23 jQuery
详解jQuery中的easyui
Sep 02 jQuery
jQuery事件多次绑定与解绑问题实例分析
Feb 19 jQuery
layui+jquery支持IE8的表格分页方法
Sep 28 jQuery
Jquery高级应用Deferred对象原理及使用实例
May 28 jQuery
jQuery实现移动端下拉展现新的内容回弹动画
Jun 24 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
第十三节--对象串行化
2006/11/16 PHP
php读取大文件示例分享(文件操作类)
2014/04/13 PHP
WordPress迁移时一些常见问题的解决方法整理
2015/11/24 PHP
PHP中set_include_path()函数相关用法分析
2016/07/18 PHP
php file_get_contents取文件中数组元素的方法
2017/04/01 PHP
PHP通过get方法获得form表单数据方法总结
2018/09/12 PHP
怎么让脚本或里面的函数在所有图片都载入完毕的时候执行
2006/10/17 Javascript
excel操作之Add Data to a Spreadsheet Cell
2007/06/12 Javascript
javascript实现的鼠标链接提示效果生成器代码
2007/06/28 Javascript
javascript 隐藏/显示指定的区域附HTML元素【legend】用法
2010/03/05 Javascript
javascript 得到变量类型的函数
2010/05/19 Javascript
js实现绿白相间竖向网页百叶窗动画切换效果
2015/03/02 Javascript
javascript中this的四种用法
2015/05/11 Javascript
使用grunt合并压缩js和css文件的方法
2017/03/02 Javascript
JavaScript累加、迭代、穷举、递归等常用算法实例小结
2018/05/08 Javascript
postman自定义函数实现 时间函数的思路详解
2019/04/17 Javascript
vue(2.x,3.0)配置跨域代理
2019/11/27 Javascript
Vue 封装防刷新考试倒计时组件的实现
2020/06/05 Javascript
举例讲解Python中is和id的用法
2015/04/03 Python
Python编程之黑板上排列组合,你舍得解开吗
2017/10/30 Python
Python编程使用*解包和itertools.product()求笛卡尔积的方法
2017/12/18 Python
Python查看微信撤回消息代码
2018/06/07 Python
在python中实现调用可执行文件.exe的3种方法
2019/07/07 Python
解决python 读取excel时 日期变成数字并加.0的问题
2019/10/08 Python
Python面向对象程序设计之静态方法、类方法、属性方法原理与用法分析
2020/03/23 Python
一组SQL面试题
2016/02/15 面试题
上海中网科技笔试题
2012/02/19 面试题
大学生个人简历自我评价
2013/11/16 职场文书
综合实践活动总结
2014/05/05 职场文书
教导主任竞聘演讲稿
2014/05/16 职场文书
《吃水不忘挖井人》教学反思
2016/02/22 职场文书
用golang如何替换某个文件中的字符串
2021/04/25 Golang
mysql如何配置白名单访问
2021/06/30 MySQL
Nginx+Windows搭建域名访问环境的操作方法
2022/03/17 Servers
Matplotlib绘制条形图的方法你知道吗
2022/03/21 Python
一篇文章带你掌握SQLite3基本用法
2022/06/14 数据库