复选框checked 选中后不显示打钩


复选框checked 选中后不显示打钩

checkbox属性checked="checked"已有,但复选框却不显示打钩的原因

 

复选框绑定了click事件,点一次选中,再点击取消选中, 第一次,可以正常显示选中和取消,但当再去选中的时候,复选框的属性checkbox值变为"checked",没问题,但是复选框却不在显示选中状态,F12发现属性值改了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,问题得解。

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM