解决jquery操作checkbox火狐下第二次无法勾选问题
来源:互联网 发布:淘宝穿越火线刷经验 编辑:程序博客网 时间:2024/06/06 01:25
最近在学习jQuery(版本jquery-1.9.1.js),要求用jQuery实现全选/全不选、反选,在IE(IE8)中没有问题,但在火狐浏览器中调试的时候出现了一些小问题,达不到效果。
html代码如下:
<div> 你爱好的运动是 <input type="checkbox" id="selectal1" /><label for="selectal1">全选/全不选</label><br/> <input name="intrest" type="checkbox" />足球 <input name="intrest" type="checkbox" />篮球 <input name="intrest" type="checkbox" />羽毛球 <input name="intrest" type="checkbox" />乒乓球<br/> <button id="allbtn">全选</button> <button id="notallbtn">全不选</button> <button id="reversebtn">反选</button> <button>提交</button> </div>
jQuery代码:
<script type="text/javascript" src="jquery-1.9.1.js"></script><script type="text/javascript"> $().ready(function(){ //全选/全不选复选框 $("#selectal1").click( function(){ if($(this).attr("checked")==true){ $("input:checkbox[id!='selectal1']").each(function() { $(this).attr("checked",true); }); }else{ $("input:checkbox[id!='selectal1']").each(function() { $(this).attr("checked",false); }); } }); //全选按钮 $("#allbtn").click(function(){ $("input:checkbox[id!='selectal1']").each(function() { $(this).attr("checked",true); }); }); //全不选按钮 $("#notallbtn").click(function(){ $("input:checkbox[id!='selectal1']").each(function() { $(this).attr("checked",false); }); }); //反选按钮 $("#reversebtn").click(function(){ $("input:checkbox[id!='selectal1']").each(function() { $(this).attr("checked",!$(this).attr("checked")); }); }); })</script>
复选框绑定了click事件,点一次选中,再点击取消选中,依次类推。这个功能在IE8中没问题,但是在firefox中测试的时候,前两次都没有问题,可以正常显示选中和取消,但当再去选中的时候,复选框的属性checkbox值变为”checked”,没问题,但是复选框却不在显示选中状态,明明属性值改了,但是却不显示勾选,我以为是浏览器缓存的问题,但是删除缓存还是不行……..后来在网上看到了方法,说是jQuery版本的问题,jQuery1.6以上用attr会存在兼容性问题,得换成prop。
查了下API prop属性是这样的:
prop(name|properties|key,value|fn)
概述
获取在匹配的元素集中的第一个元素的属性值。
随着一些内置属性的DOM元素或window对象,如果试图将删除该属性,浏览器可能会产生错误。jQuery第一次分配undefined值的属性,而忽略了浏览器生成的任何错误
jQuery API明确说明,1.6+的jQuery要用prop,尤其是checkBox的checked的属性的判断,于是乎把js代码里面的attr换成prop就行了
代码:
//1.6+的jQuery要用prop代替attr否则达不到效果!!!! //全选/全不选复选框 $("#selectal1").click( function(){ if($(this).prop("checked")==true){ $("input:checkbox[id!='selectal1']").each(function() { $(this).prop("checked",true); }); }else{ $("input:checkbox[id!='selectal1']").each(function() { $(this).prop("checked",false); }); } }); //全选按钮 $("#allbtn").click(function(){ $("input:checkbox[id!='selectal1']").each(function() { $(this).prop("checked",true); }); }); //全不选按钮 $("#notallbtn").click(function(){ $("input:checkbox[id!='selectal1']").each(function() { $(this).prop("checked",false); }); }); //反选按钮 $("#reversebtn").click(function(){ $("input:checkbox[id!='selectal1']").each(function() { $(this).prop("checked",!$(this).prop("checked")); }); });
希望对大家有所帮助^_^
0 0
- jquery操作checkbox,火狐下第二次无法勾选问题
- 解决jquery操作checkbox火狐下第二次无法勾选问题
- 解决jquery操作checkbox火狐下第二次无法勾选问题
- 解决jquery操作checkbox火狐下第二次无法勾选问题
- 解决jquery操作checkbox全选全不选无法勾选问题
- 解决jquery操作checkbox全选全不选无法勾选问题
- 解决jquery操作checkbox全选全不选无法勾选问题
- 解决jquery操作checkbox全选全不选无法勾选问题
- 解决jquery操作checkbox全选全不选无法勾选问题
- jquery操作checkbox第二次无法勾选问题
- JQuery操作CheckBox 第二次无法选中的问题
- JQuery操作CheckBox 第二次无法选中的问题
- 解决jQuery操作checkbox第二次失效的问题
- jquery操作checkbox在二次选中勾选框时失效
- jquery操作checkbox的问题
- jquery checkbox 全选反选,解决第二次失败的问题
- ie9下checkbox无法二次全选
- 解决火狐下焦点无法重复获取问题------神器版!
- Tomcat在window下直接启动出现一闪而过
- JavaScript 的类型检测
- [Javascript] 闭包 closure
- iOS——关于应用程序生命周期问题
- jquery信息提示插件poshytip 和弹出框插件 jbox,树状图插件ztree,图表插件echarts
- 解决jquery操作checkbox火狐下第二次无法勾选问题
- 腾讯产品总监曹菲-----为何我工作十年,内心仍无比恐慌
- C语言--指针2
- 17 Letter Combinations of a Phone Number
- lov制作注意点
- Android(14)Handler简单例子(1)
- 设计模式(九)装饰模式(Decorator)
- JavaScript中IE与DOM事件的区别http://www.cnblogs.com/stpangpang/archive/2008/06/03/1212607.html
- 单例模式下的嵌套调用导致栈溢出