jquery 版本兼容性问题集合

本文针对从旧版jQuery(如1.4.2)升级到新版(如1.10)时遇到的问题进行总结,特别是关于事件委托和checked属性操作的变化。通过示例代码对比,介绍如何正确使用新版API,避免常见陷阱。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


使用jquery的很多时候代码还是停留在过去1.2.6,1.4.2这些版本的API用法上面,其实之后的版本修改了很多,所以不小心会碰到很多坑,这里不停的更新列举下问题:

先看一段常规的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);
			}
		});

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值