码迷,mamicode.com
首页 > 其他好文 > 详细

attr与prop

时间:2015-08-31 14:57:17      阅读:158      评论:0      收藏:0      [点我收藏+]

标签:

Jquery获取checkbox属性checked为undefined (2014-06-12 19:51:22)转载▼
标签: js jquery checkbox checked undefined    分类: JQuery
使用jQuery v1.10.2获取checkbox的状态时,用.attr("checked")时输出总是为undefined.郁闷了,这难道是个bug?!

查看jQuery API的文档,发现:
As of jQuery 1.6, the .attr() method returns undefined for attributes that have not been set. In addition, .attr() should not be used on plain objects, arrays, the window, or the document. To retrieve and change DOM properties, use the .prop() method.
The difference between attributes and properties can be important in specific situations. Before jQuery 1.6, the .attr() method sometimes took property values into account when retrieving some attributes, which could cause inconsistent behavior. As of jQuery 1.6, the .prop() method provides a way to explicitly retrieve property values, while .attr() retrieves attributes.

也就说:v1.6以后attr(‘checked’)就返回checked和undefined,v1.6以前返回true和false,v1.6以后可以使用is(‘:checked’)或者.prop(‘checked’)来返回true和false

总结:
(1)获取checked的方法
    .attr(checked):  
    .prop(checked): //1.6+:true/false
    .is(:checked):   
(2)checked赋值

     所有的jquery版本都可以这样赋值:
     .attr("checked","checked");
     .attr("checked",true);

      jquery1.6以上版本的:
     .prop("checked",true);
    .prop("checked","checked");
    .prop({checked:true});
     .prop("checked",function(){
              return true;
      });

(3)note:jquery1.6以上才存在prop();

 

attr与prop

标签:

原文地址:http://www.cnblogs.com/itboy-2009/p/4772846.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!