通過(guò)源碼可見(jiàn),靜態(tài)方法是直接操作數(shù)據(jù)類(lèi)的 data_user.access 方法
jQuery.extend({ data: function(elem, name, data) { return data_user.access(elem, name, data) }
靜態(tài)方法data的實(shí)現(xiàn)不像attr操作直接把數(shù)據(jù)作為屬性捆綁到元素節(jié)點(diǎn)上,如果為DOM Element 附加數(shù)據(jù);DOM Element 也是一種 Object ,但 IE6、IE7 對(duì)直接附加在 DOM Element 上的對(duì)象的垃圾回收存在問(wèn)題;因此我們將這些數(shù)據(jù)存放在全局緩存(我們稱(chēng)之為“globalCache”)中,即 “globalCache” 包含了多個(gè) DOM Element 的 “cache”,并在 DOM Element 上添加一個(gè)屬性,存放 “cache” 對(duì)應(yīng)的 uid。
最后可見(jiàn):
1:jQuery.data(element,[key],[value]),每一個(gè)element都會(huì)有自己的一個(gè){key:value}對(duì)象保存著數(shù)據(jù),所以新建的對(duì)象就算有key相同它也不會(huì)覆蓋原來(lái)存在的對(duì)象key所對(duì)應(yīng)的value,因?yàn)樾聦?duì)象保存是是在另一個(gè){key:value}對(duì)象中
2:$("div").data("a","aaaa") 它是把數(shù)據(jù)綁定每一個(gè)匹配div節(jié)點(diǎn)的元素上
源碼可以看出來(lái),說(shuō)到底,數(shù)據(jù)緩存就是在目標(biāo)對(duì)象與緩存體間建立一對(duì)一的關(guān)系,整個(gè)Data類(lèi)其實(shí)都是圍繞著 thia.cache 內(nèi)部的數(shù)據(jù)做增刪改查的操作。
請(qǐng)驗(yàn)證,完成請(qǐng)求
由于請(qǐng)求次數(shù)過(guò)多,請(qǐng)先驗(yàn)證,完成再次請(qǐng)求
打開(kāi)微信掃碼自動(dòng)綁定
綁定后可得到
使用 Ctrl+D 可將課程添加到書(shū)簽
舉報(bào)