jquery的attr的一些bug
2016-01-16 15:56
573 查看
最近在调试复选框的应用,在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,问题得解。
你遇到这个奇怪的问题了吗?赶紧试试吧
相关文章推荐
- Jquery 动画效果 左右移动
- jquery tmpl 详解
- jQuery Ajax 实例
- Atitit.jquery 版本号新特性attilax总结
- js/jquery使用记录
- FlexSlider是一个非常出色的jQuery滑动切换插件
- JQuery.ajsx实例
- jquery中奖实例代码
- jquery手机全屏上下滑动
- jQuery实现图片走马灯效果的原理分析
- jQuery ajax()使用serialize()提交form数据
- 关于jquery动态加载li时点击事件无法加载的问题
- jQuery实现图片走马灯效果的原理分析
- myeclipse 增加javascript提示和jquery提示等不用安装插件自带功能
- jQuery-ajax: 取消关注|关注
- jquery ui 学习随笔 自动补全
- jQuery-动画效果animate() slideDown() slideUp() fadeIn() fadeOut()
- jquery.form.js使用
- jQuery弹窗组件 colorbox
- Jquery 动画效果