关于jquery中attr()和prop()方法的区别
最近项目回归使用jquery,页面渲染全是使用jquery做的,所以做的时候也遇到了许多以前没有见过的问题,如这次操作【radio】控件的"checked"属性时有遇到问题,
$("...").attr("checked",false);
无法起到作用,上网查了下使用prop()完美的解决了该问题,特此记录一下。
官方定义:attr():
attr() 方法设置或返回被选元素的属性和值。
当该方法用于返回属性值,则返回第一个匹配元素的值。
当该方法用于设置属性值,则为匹配元素设置一个或多个属性/值对。
prop():
prop() 方法设置或返回被选元素的属性和值。
当该方法用于返回属性值时,则返回第一个匹配元素的值。
当该方法用于设置属性值时,则为匹配元素集合设置一个或多个属性/值对。
$('').attr()返回的是html对象
$('').prop()返回的是dom对象
prop()
方法操作radio(checkbox)之类的控件,让其选中的时候,其控件选中的值也会随之改变。即既可以控制其选中,也能控制其取消选中;
类似于$("...").attr("checked");返回的是true或者false
如果有相应的属性,返回的是该属性,如果没有则返回空串
attr()
方法操作adio(checkbox)之类的控件,让其选中的时候,其控件选中的值不会随之改变。即只能控制其选中,不能控制其取消选中;
类似于$("...").attr("checked");返回的是'checked'或者undefined
如果有相应的属性,返回的是该属性,如果没有则返回undefined
attr和prop的使用场景:
1.添加属性名称该属性就会生效应该使用prop();
2.是有true,false两个属性使用prop();(如'checked','selected','disabled'等)
3.其他则使用attr();
官方推荐使用:
上一篇: 微信卖货技巧,如何让顾客主动找你?
下一篇: 味美汁多的汕头牛肉丸,你真的会吃吗?
推荐阅读
-
java中timer的schedule和scheduleAtFixedRate方法区别详解
-
Java中关于int和Integer的区别详解
-
老生常谈jquery中detach()和remove()的区别
-
attr()和prop()的区别解析
-
详解Node.js中path模块的resolve()和join()方法的区别
-
JavaScript中的 attribute 和 jQuery中的 attr 方法浅析
-
深入理解jQuery中live与bind方法的区别
-
jquery prop的使用介绍及与attr的区别
-
浅析ThinkPHP中execute和query方法的区别
-
JavaScript中的toString()和toLocaleString()方法的区别