checkbox已设置为checked--true-但不勾选问题解决方法(只第一次勾选有效)

一、出现的问题及解决方法:
今天在写一个table相关插件的时候无意中发现了这样一个问题,记得以前在写这种控制checkbox选中与非选中的代码时并没有这种bug,当时也是用的checked属性,而现在却行不通了。

于是乎做了以下测试,测试demo:一个按钮控制checkbox的选中状态。
这里写图片描述
测试js代码:

        $("#test_btn").click(function(){

            var state = $("#test_check").attr('checked');
            $("#test_check").attr('checked',!state);

        })

效果是第一回合点击有效:第一次点击选中,第二次点击非选中,从第三次点击开始就没有任何反应了,但是checkbox元素的checked属性却依然在切换:
这里写图片描述
即使是checked:”checked”也依然是非选中状态。当时我就懵逼了,wtf。
查了查jquery版本,版本还挺新:
这里写图片描述
不是版本问题,突然想起控制checkbox选中状态的还有prop();遂拿来死马当活马医:

        $("#test_btn").click(function(){

            var state = $("#test_check").prop('checked');
            $("#test_check").prop('checked',!state);


        })

解决问题,完美。来不及自我欣赏,迅速反过来查了查jquery中prop和attr的区别,立马恍然大悟后知后觉。

二、jquery中的attr和prop区别
在高版本的jquery引入prop方法后,什么时候该用prop?什么时候用attr?它们两个之间有什么区别?这些问题就出现了。
关于它们两个的区别,网上的答案很多,其实很简单:
对于HTML元素本身就带有的固有属性,在处理时,使用prop方法。
对于HTML元素我们自己自定义的DOM属性,在处理时,使用attr方法。
举个栗子:

<a href="#" class="a" id="b" action="delete"></a>

栗子中,a元素的DOM属性有“href、id和action”,很明显,前两个是固有属性,而后面一个“action”属性是我们自己自定义上去的,a元素本身是没有这个属性的。这种就是自定义的DOM属性。处理这些属性时,建议使用attr方法。使用prop方法取值和设置属性值时,都会返回undefined值。

现在再说说我们之前那个栗子,也就是checkbox的问题。

<input type="checkbox" id="test_check1">
<input type="checkbox" id="test_check2" checked='checked'>

像checkbox,radio和select这样的元素,选中属性对应“checked”和“selected”,这些也属于固有属性,因此需要使用prop方法去操作才能获得正确的结果。
而如果使用attr:

$("#test_check1").attr("checked") == undefined
$("#test_check2").attr("checked") == "checked"

而如果使用prop,则正常:

$("#test_check1").prop("checked") == false
$("#test_check2").prop("checked") == true

所以归根到底就是attr和prop的区别。

评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值