jquery中的attr和prop区别
2016-10-20 11:47
302 查看
jquery中的attr和prop区别
在高版本的jquery引入prop方法后,什么时候该用prop?什么时候用attr?它们两个之间有什么区别?这些问题就出现了。
关于它们两个的区别,网上的答案很多,其实很简单:
对于HTML元素本身就带有的固有属性,在处理时,使用prop方法。
对于HTML元素我们自己自定义的DOM属性,在处理时,使用attr方法。
栗子中,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
在高版本的jquery引入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
相关文章推荐
- jquery中prop()方法和attr()方法的区别浅析
- jquery中prop()方法和attr()方法的区别
- jquery中prop()方法和attr()方法的区别
- jquery中prop()方法和attr()方法的区别浅析
- jQuery学习之prop和attr的区别
- jquery中prop()方法和attr()方法的区别浅析
- jquery中attr和prop的区别
- jQuery 中 attr() 和 prop() 方法的区别
- jQuery学习之prop和attr的区别
- jquery中prop()方法和attr()方法的区别(转)
- jQuery学习之prop和attr的区别示例介绍
- jquery中prop和attr的区别有哪些
- jquery prop方法和attr方法区别
- jQuery学习之prop和attr的区别
- jquery中prop()方法和attr()方法的区别【转】
- jQuery学习之prop和attr的区别示例介绍
- jquery中prop()方法和attr()方法的区别
- jQuery 中 attr() 和 prop() 方法的区别
- jquery中prop()方法和attr()方法的区别
- jquery中prop()方法和attr()方法的区别