展会信息港展会大全

解决jquery操作checkbox火狐下第二次无法勾选问题
来源:互联网   发布日期:2016-03-24 20:12:23   浏览:1576次  

导读:在工作中使用jquery操作checkbox,进行全� ⒎囱。?衷诘奈侍馐腔鸷?碌诙?挝薹ü囱∥侍猓?谙旅嬗懈鱿晗傅慕獯穑?行巳さ呐笥芽梢圆慰枷伦罱?诠ぷ髦惺褂胘query操作checkbox...

在工作中使用jquery操作checkbox,进行全癣反选,现在的问题是火狐下第二次无法勾选问题,在下面有个详细的解答,感兴趣的朋友可以参考下

最近在工作中使用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,问题得解。

你遇到这个奇怪的问题了吗?赶紧试试吧

赞助本站

人工智能实验室

相关热词: 开发 编程 android

AiLab云推荐
展开

热门栏目HotCates

Copyright © 2010-2024 AiLab Team. 人工智能实验室 版权所有    关于我们 | 联系我们 | 广告服务 | 公司动态 | 免责声明 | 隐私条款 | 工作机会 | 展会港