checkbox设置checked--true-但不勾选(使用$.attr('checked',true))无效

转载 2017年01月03日 11:50:03

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

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

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

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

        })
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

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

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

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


        })
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

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

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

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

栗子中,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'>
  • 1
  • 2
  • 1
  • 2

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

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

而如果使用prop,则正常:

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

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

jquery checkbox反复调用attr('checked', true/false)只有第一次生效

/** * 全选 */ function checkAll() { $("input[name=ids]").attr("checked", true); ...
  • tunzao
  • tunzao
  • 2013年12月09日 16:32
  • 16841

jquery,attr,prop,checkbox标签已有checked=checked但是不显示勾选

最近在做项目的过程中碰到了这样的一个问题:在使用bootstrap模态框的过程中,在模态框中有一个checkbox标签,一开始是为选中的,当点击触发模态框按钮,选中chcekbox时,会显示勾选,这个...
  • wsmeichao1
  • wsmeichao1
  • 2015年08月12日 15:48
  • 2257

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

一、出现的问题及解决方法: 今天在写一个table相关插件的时候无意中发现了这样一个问题,记得以前在写这种控制checkbox选中与非选中的代码时并没有这种bug,当时也是用的checked属性,而...
  • alex2917
  • alex2917
  • 2016年04月10日 10:15
  • 19060

checkbox利用JQuer中 attr('checked', true)设置状态只有第一次有用

在JQuery中可以使用attr()来访问对象的属性,但是在某些时候,比如访问input的disabled属性的时候,会有些问题。在有的浏览器中,只要写了disabled属性就可以,有的则要写:dis...
  • qq_27626333
  • qq_27626333
  • 2016年12月18日 11:42
  • 1080

Jquery 中 $('obj').attr('checked',true)失效的几种解决方案

1、$('obj').prop('checked',true) 2、 $(':checkbox').each(function(){     this.checked=true;     })...
  • medaka
  • medaka
  • 2015年11月18日 10:30
  • 4802

$('#checkbox').attr('checked'); 返回的是checked或者是undefined解决办法

$('#checkbox').attr('checked'); 返回的是checked或者是undefined,不是原来的true和false了,有关此问题的解决方法如下 在JQ1.6之前的...
  • awj3584
  • awj3584
  • 2014年03月18日 17:10
  • 39927

$("input[name=choose]").attr("checked", true);只执行一次,再次点击没有作用

function test(){          var flag=$("#aaa").is(':checked');                  if(flag){        ...
  • builderwfy
  • builderwfy
  • 2016年09月13日 10:05
  • 1801

checkbox属性checked="checked"已有,但却不显示打勾的解决办法

在做权限管理的时候,做了一个功能,就是当勾选栏目,把所有的权限全勾上。刚开始使用了如下代码: function check(id,check) { if (check) { $("." + i...
  • anxin591025
  • anxin591025
  • 2014年09月29日 16:48
  • 13609

$('#checkbox').attr('checked') 返回ture和checked 的原因

jquery 1.6 版本
  • pshaoyi
  • pshaoyi
  • 2014年07月01日 16:05
  • 531

attr和prop的区别-解决checkbox选中不起作用的问题

今天在写checkbox的全选,半全选时遇到了一个问题,刚开始点击全选按钮时,可以全选,再点击可以全部清除选中,再点击就不起作用了?         我打开审查元素发现,第三次点击应该是全选的状态,这...
  • hardgirls
  • hardgirls
  • 2016年07月14日 09:19
  • 1629
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:checkbox设置checked--true-但不勾选(使用$.attr('checked',true))无效
举报原因:
原因补充:

(最多只允许输入30个字)