jquery 版本兼容性问题集合
2013-09-22 01:01
260 查看
使用jquery的很多时候代码还是停留在过去1.2.6,1.4.2这些版本的API用法上面,其实之后的版本修改了很多,所以不小心会碰到很多坑,这里不停的更新列举下问题:
先看一段常规的1.4.2版本的代码:
会发现这段代码在1.10这个版本中出现很多问题,首先attr这个属性在高版本的jquery中获取选择的状态,就会有各种问题;
其次在使用attr变为某个值之后,比如attr('checked', true);去看下html的源码,会发现checkbox的源码中多了checked="checked"
即使使用.attr('checked', false); 也无法修改其属性;
所以最后修改为:
先看一段常规的1.4.2版本的代码:
$("#categoryAndItems div").delegate("input[type='checkbox']:eq(0)", 'click', function(){ if ($(this).attr('checked')) { console.log('c=' + $(this).prop('checked')); $(this).parent().parent().find("input[type='checkbox']:gt(0)").attr('checked', true); } else { $(this).parent().nextAll().find("input[type='checkbox']").attr('checked', false); } });
会发现这段代码在1.10这个版本中出现很多问题,首先attr这个属性在高版本的jquery中获取选择的状态,就会有各种问题;
其次在使用attr变为某个值之后,比如attr('checked', true);去看下html的源码,会发现checkbox的源码中多了checked="checked"
即使使用.attr('checked', false); 也无法修改其属性;
所以最后修改为:
$("#categoryAndItems div").on('click', "input[type='checkbox']:eq(0)", function(){ console.log('c=' + $(this).prop('checked')); if ($(this).prop('checked')) { console.log('check='); $(this).parent().parent().find("input[type='checkbox']:gt(0)").prop('checked', true); } else { $(this).parent().parent().find("input[type='checkbox']:gt(0)").prop('checked', false); } });
相关文章推荐
- 关于juqery radio写法的兼容性问题(新老版本jquery)
- 处理不同jQuery版本的兼容性问题
- jquery1.3版本以上使用数组对struts2的兼容性问题
- 关于juqery radio写法的兼容性问题(新老版本jquery)
- 通过js框架jquery判断IE浏览器版本来解决浏览器兼容性问题
- 引入不同的jquery版本,对ContentType的设置方式有不同(问题)
- 灵活使用编译宏解决平台或版本的兼容性问题
- jquery版本升级不兼容的问题:$("input").attr("value")功能发生改变
- jQuery1.9+ 废弃的函数和方法 升级Jquery版本遇到的问题
- jquery-multiselect取值、刷新页面保持选中、AJAX相关问题集合
- 使用jquery 解决window.event 带来的兼容性问题
- C++中unordered_map的版本兼容性问题
- jquery-scrollTop() 兼容性问题-如何解决
- Oracle RMAN 兼容性 及 不同版本和不同平台之间使用 常见问题说明
- Jquery 版本兼容性 attr("checked") 返回undefined或失效
- 常见兼容性问题集合
- PJSIP开源库对windows嵌入式版本的兼容性问题
- App Store 版本兼容性显示问题
- 页面多个Jquery版本共存的冲突问题,解决方法!
- Oracle RMAN 兼容性 及 不同版本和不同平台之间使用 常见问题说明