解决jquery操作checkbox火狐下第二次无法勾选问题


Posted in Javascript onFebruary 10, 2014

最近在工作中使用jquery操作checkbox,使用下面方法进行全选、反选:

var ischecked=allCheckObj.is(':checked'); 
ischecked?checksObj.attr('checked',true):checksObj.attr('checked',false);

调试时在ie没有问题,考虑到兼容性,试试了firefox,遇到了问题。于是乎,做了如下实验:
复选框绑定了click事件,点一次选中,再点击取消选中,依次类推。这个功能在ie中没问题,但是在firefox中测试的时候,前两次都没有问题,可以正常显示选中和取消,但当再去选中的时候,复选框的属性checkbox值变为"checked",没问题,但是复选框却不在显示选中状态,明明属性值改了,但是却不显示勾选,太诡异了。代码修改了却得不到正确的显示状态,纠结了很久,找不到原因。
正解:后来经偶像指点,原来是jQuery版本问题。我操作属性用的是
$("**").attr("attrName");而jQuery的版本用的是1.9,这就是存在一个兼容性和稳定性问题。
jQuery API明确说明,1.6+的jQuery要用prop,尤其是checkBox的checked的属性的判断,即
$("input[type='checkbox']").prop("checked"); 
$("input[type='checkbox']").prop("disabled", false); 
$("input[type='checkbox']").prop("checked", true);

在使用是将attr改为prop,问题得解。
你遇到这个奇怪的问题了吗?赶紧试试吧
Javascript 相关文章推荐
cocos2dx骨骼动画Armature源码剖析(三)
Sep 08 Javascript
jQuery实现div拖拽效果实例分析
Feb 20 Javascript
js解决movebox移动问题
Mar 29 Javascript
Bootstrap每天必学之模态框(Modal)插件
Apr 26 Javascript
jQuery基础的工厂函数以及定时器的经典实例分析
May 20 Javascript
Bootstrap框架下下拉框select搜索功能
Mar 26 Javascript
jquery遍历标签中自定义的属性方法
Sep 17 Javascript
详解javascript立即执行函数表达式IIFE
Feb 13 Javascript
angularjs $http实现form表单提交示例
Jun 09 Javascript
微信小程序实现多行文字超出部分省略号显示功能
Oct 23 Javascript
vue.js实现点击图标放大离开时缩小的代码
Jan 27 Vue.js
VUE解决跨域问题Access to XMLHttpRequest at
May 06 Vue.js
js判断undefined类型示例代码
Feb 10 #Javascript
jQuery-ui引入后Vs2008的无智能提示问题解决方法
Feb 10 #Javascript
js网页实时倒计时精确到秒级
Feb 10 #Javascript
js格式化时间和js格式化时间戳示例
Feb 10 #Javascript
javaScript 页面自动加载事件详解
Feb 10 #Javascript
页面图片浮动左右滑动效果的简单实现案例
Feb 10 #Javascript
点击弹出层效果&弹出窗口后网页背景变暗效果的实现代码
Feb 10 #Javascript
You might like
Mac系统下安装PHP Xdebug
2018/03/30 PHP
PHP实现微信小程序人脸识别刷脸登录功能
2018/05/24 PHP
PHP命名空间定义与用法实例分析
2019/08/14 PHP
javascript 有趣而诡异的数组
2009/04/06 Javascript
JavaScript实现班级随机点名小应用需求的具体分析
2014/05/12 Javascript
Javascript中this的用法详解
2014/09/22 Javascript
js实现刷新iframe的方法汇总
2015/04/27 Javascript
JavaScript Length 属性的总结
2015/11/02 Javascript
全面介绍javascript实用技巧及单竖杠
2016/07/18 Javascript
彻底学会Angular.js中的transclusion
2017/03/12 Javascript
d3.js入门教程之数据绑定详解
2017/04/28 Javascript
javascript 作用于作用域链的详解
2017/09/27 Javascript
浅谈Vue-cli 命令行工具分析
2017/11/22 Javascript
Angularjs Promise实例详解
2018/03/15 Javascript
angularJS1 url中携带参数的获取方法
2018/10/09 Javascript
vue-cli+webpack项目打包到服务器后,ttf字体找不到的解决操作
2020/08/28 Javascript
Python中常见的数据类型小结
2015/08/29 Python
python3.0 模拟用户登录,三次错误锁定的实例
2017/11/02 Python
tensorflow更改变量的值实例
2018/07/30 Python
python正则表达式匹配[]中间为任意字符的实例
2018/12/25 Python
详解用Python实现自动化监控远程服务器
2019/05/18 Python
Python3 chardet模块查看编码格式的例子
2019/08/14 Python
IE9下html5初试小刀
2010/09/21 HTML / CSS
让IE下支持Html5的placeholder属性的插件
2014/09/02 HTML / CSS
整理HTML5中表单的常用属性及新属性
2016/02/19 HTML / CSS
印度网上药店:1mg
2017/10/13 全球购物
微软日本官方网站:Microsoft日本
2017/11/26 全球购物
Ray-Ban雷朋奥地利官网:全球领先的太阳眼镜品牌
2020/10/12 全球购物
可靠的数据流传输TCP
2016/03/15 面试题
优秀员工自荐信范文
2013/10/05 职场文书
生日寿宴答谢词
2014/01/19 职场文书
祖国在我心中演讲稿600字
2014/09/23 职场文书
大学运动会加油稿
2015/07/22 职场文书
干货:我将这样书写我的演讲稿!
2019/05/09 职场文书
MongoDB balancer的使用详解
2021/04/30 MongoDB
深入理解Vue的数据响应式
2021/05/15 Vue.js