jq:prop()、attr()、data()异同

attr()方法:
1、JS中getAttribute()和setAttribute()方法的集成体,用法最为常规,通过attr()方法获得的属性,在HTML页面检查元素中都可以看到该属性;
2、attr()的设计目标是用于设置或获取指定DOM元素所对应的文档节点上的属性(attribute);
3、设置的属性值只能是字符串类型;
4、attr()返回的是字符串。

prop()方法:
1、比较安全和隐秘的方法,设置属性和获得属性与attr()方法一致的用法;
2、prop()在对radio,select,checkbox进行选中属性操作的时候,值为true/false;
3、prop()的设计目标用于设置或获取指定DOM元素(指的是JS对象,Element类型)上的属性(property);
4、prop()操作的是js对象的属性,设置的属性值可以为包括数组和对象在内的任意类型;
5、prop()可以返回很多类型。

data()方法:
1、更为安全、隐秘的方法,属性名称前面加上data-;
2、data()设置值后,attr()不能获取设置后的值。

从性能上对比,.prop() > .data() > .attr(),不同浏览器不同版本.data()和.attr()的性能关系有差异,不过.prop()总是最优的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值