zoukankan      html  css  js  c++  java
  • 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”也依然是非选中状态。

    问题就在jquery中的attr和prop区别 :

    二、jquery中的attr和prop区别 
    在高版本的jquery(jQuery API明确说明,1.6+的jQuery要用prop)引入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的区别。

     参考原文:http://blog.csdn.net/alex2917/article/details/51111431
          http://blog.sina.com.cn/s/blog_6657f20e0101g793.html
  • 相关阅读:
    ASIHTTPRequest详解
    UIViewController之间的相互跳转
    IOS延时加载网络图片
    ASI 实现注册方法的小例子(get和post方式)
    NSRange
    NSScanner
    序列化 NSKeyedArchiver,NSPropertyListSerialization
    自定义UITableViewCell
    UITableView去掉分隔符
    ASIHTTPRequest类库简介和使用说明(转)
  • 原文地址:https://www.cnblogs.com/fatty-yu/p/7640150.html
Copyright © 2011-2022 走看看