对 jQuery 中 data 方法的误解分析

 http://www.jb51.net/article/51215.htm

一直以来都认为新版本中 data 是调用 dataset 实现的,对于低版本IE则采用 getAttribute其实一直是我误解了,也不知道最初这个想法是怎么来的

今天 谢亮 兄弟和我讨论一个东西的时候,谈到了性能,他用的是 attr 操作自定义属性 data-uid,我说用 data 好,因为是 dataset 实现,然后他去翻了下 jQuery 源码和我说,没有发现这个东西,我就纳闷了。于是我去仔细读了下 data 方法的源码,才发现我一直误会了,再此,向之前问我 data 方法的群友道歉,我 "骗" 了你们,你们来打我吧。

今天我就重新解释下 data 方法,先看下 jQuery 1.11.0 的手册里肿么说的吧,请移步至http://shouce.jb51.net/jquery/data.html
用法这里说的很清楚了,但是内部是怎么实现的呢? 戳我看源码  (看不懂没关系,我会简单分析下他的流程)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
其实是这样的,当我们执行例如这样的语句时 $( "#id" ).data( "test" ); (简化后的过程)
第一步: jQuery 会获取到 $( "#id" ) 元素,对吧、
第二步: 执行到 data方法 的时候,他会通过 attributes 取我们要的对应值。
第三步: 返回结果给我们,然后 jQuery 把值缓存到内部对象里
第一次取的时候,我们可以得到的 undefined,字符串,数字或者解析后的json。
  
那有人会说这个和 attr 有什么区别呢?
当我们第二次执行 $( "#id" ).data( "test" ); 的时候:
第一步: jQuery 会获取到 $( "#id" ) 元素,和上面一样。
第二步: 执行到 data方法 的时候,从 jQuery 的缓存中取值
第三步: 返回结果给我们
  
发现第二步不同了,对吧,为什么不是从 attributes 取值,而是从缓存中取呢?
缓存其实是js的对象,简单说就类似 var cache = {}; jQuery 在第一次取值之后就会保存到这个缓存对象中,这样我们再次操作的时候就非常快了、
往往性能的损耗都是在 dom 操作上,所以避免重复操作 dom 是非常必要的。
  
到这,也能看出他和 attr 最大的区别了,比如 <div id= "id" data-test= "hehe" ></div>
$( "#id" ).data( "test" , "123" ); 执行后依然是 data-test= "hehe"
$( "#id" ).attr( "data-test" , "123" ); 执行后会是 data-test= "123"
  
那么我们要给一个元素赋值值,或者对象的时候他们有什么区别呢?比如 <div id= "id" data-test= "hehe" ></div>
$( "#id" ).data( "test" , {str: "hehe" }); 会把 {str: "hehe" } 赋值给 缓存,元素节点上依然是 data-test= "hehe"
$( "#id" ).attr( "data-test" , {str: "hehe" }); 执行后会是 data-test= "[object Object]"
这个应该也有不少人遇到,至少群里有不少人问过这个问题。

其实我之前也没骗你们,自定义属性没必要老是 attr 他,data 是 jQuery 赋予我们的一把瑞士军刀,非常锋利的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值