firefox中 checkbox属性checked="checked"已有,但复选框却不显示打钩的原因
2016-03-29 00:10
274 查看
最近在调试复选框的应用,在ie没有问题,考虑到兼容性,试试了firefox,遇到了问题。
复选框绑定了click事件,点一次选中,再点击取消选中,依次类推。这个功能在ie中没问题,但是在firefox中测试的时候,前两次都没有问题,可以正常显示选中和取消,但当再去选中的时候,复选框的属性checkbox值变为"checked",没问题,但是复选框却不在显示选中状态,明明属性值改了,但是却不显示勾选,太诡异了。代码修改了却得不到正确的显示状态,纠结了很久,找不到原因。
正解:后来经偶像指点,原来是jQuery版本问题。我操作属性用的是
复选框绑定了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,问题得解。
你遇到这个奇怪的问题了吗?赶紧试试吧~~
相关文章推荐
- 循环
- 多线程学习1
- JavaScript API 设计原则
- Java并发:终止线程和关闭线程池
- java-socket多线程网络编程案列--搭建本地简易聊天对话服务器
- LeetCode : First Missing Positive [java]
- 慕课网【PHP】3.27前所学学习内容纪要(1)
- float-浮动去空格
- mysql安装到最后一步无响应的问题解决
- iOS:代理(delegate)理解及使用
- gradle命令行操作android studio
- [设计模式]模板模式
- Java方法中加泛型与不加区别
- CodeForces 651C Watchmen
- 【有源汇上下界费用流】BZOJ 3876 [Ahoi2014]支线剧情
- 平衡二叉树
- Android Bitmap占用内存计算公式
- 页面刷新两次为什么取不到值
- Windows各版本官方原版系统下载
- dip,px,sp区别及使用场景