jQuery 源码分析笔记(6) jQuery.data


Posted in Javascript onJune 08, 2011

data部分的代码从1381行开始。最开始的几行关键代码:

jQuery.extend({ 
// 存储数据的地方,关键实现核心 
cache: { }, 
// 分配ID用的seed 
uuid: 0, 
// 为了区别不同的jQuery实例存储的数据,使用前缀+jQuery版本号+随机数作为Key 
expando: "jQuery" + (jQuery.fn.jquery + Math.random()).replace(/\D/g, ""), 
// 以下元素没有Data:embed和applet(这玩意还活着么),除了Flash之外的object。 
noData: { 
"embed": true, 
"object": "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000", 
"applet": true 
} 
});

对外的接口都调用了两个内部函数:jQuery.data(elem, name, data, pvt)和jQuery.removeData(elem, name, pvt)。而removeData的逻辑与data类似,只是data是加入数据,而removeData使用delete或者设置为null删除数据。
data部分的代码中明确区分了JS对象和DOM对象的保存,这是为了解决部分浏览器的内存泄漏问题。在低版本IE中,当DOM和JS对象之间出现循环引用时,GC就无法正确处理。参见Understanding and Solving Internet Explorer Leak Patterns。至于COM对象,因为已经限制object元素没有data,就绕过了这个问题。
data: function(elem, name, data, pvt) { 
// 如果属于noData中定义的元素 
if(!jQuery.acceptData(elem)) { 
return; 
} 
var internalKey = jQuery.expando, 
getByName = typeof name === "string", 
thisCache, 
isNode = elem.nodeType, 
// DOM元素需要保存在Cache,JS对象直接保存到elem 
cache = isNode ? jQuery.cache : elem, 
// 如果elem的jQuery.expando已经有值了,就重用 
id = isNode ? elem[jQuery.expando] : elem[jQuery.expando] && jQuery.expando; 
<PRE class=brush:;gutter:true;><CODE>// data未定义,说明当前调用是查询数据,但是对象没有任何数据,直接返回 
if((!id || (pvt && id && !cache[id][internalKey])) && getByName && data === undefined) { 
return; 
} 
if(!id) { 
if(isNode) { 
// 用uuid种子递增分配唯一ID,只有DOM元素需要。因为需要存在全局cache中 
elem[jQuery.expando] = id = ++jQuery.uuid; 
} else { 
id = jQuery.expando; 
} 
} 
// 清空原来的值 
if(!cache[id]) { 
cache[id] = {}; 
if(!isNode) { 
cache[id].toJSON = jQuery.noop; 
} 
} 
// 用extend扩展cache,增加一个属性,用来保存数据 
if(typeof name === "object" || typeof name === "function") { 
if(pvt) { 
cache[id][internalKey] = jQuery.expand(cache[id][internalKey], name); 
} else { 
cache[id] = jQuery.extend(cache[id], name); 
} 
} 
thisCache = cahce[id]; 
// 避免Key冲突 
if(pvt) { 
if(!thisCache[internalKey]) { 
thisCahce[internalKey] = {}; 
} 
thisCache = thisCache[internalKey]; 
} 
if(data !== undefined) { 
thisCache[jQuery.camelCase(name)] = data; 
} 
return getByName ? thisCache[jQuery.camelCase(name)] : thisCache; 
} 
removeData: function( elem, name, pvt ) { // 前面部分与data类似 // ... // 部分浏览器不支持在Element上进行delete操作,在jQuery.support中检查过这个浏览器特性。 // 如果delete失败的话,就先设置成null。 if ( jQuery.support.deleteExpando || cache != window ) { delete cache[ id ]; } else { cache[ id ] = null; } 
<PRE class=brush:;gutter:true;><CODE>var internalCache = cache[ id ][ internalKey ]; 
// 如果还有数据,就清空一次再设置,增加性能 
if ( internalCache ) { 
cache[ id ] = {}; 
cache[ id ][ internalKey ] = internalCache; 
// 已经没有任何数据了,就全部删除 
} else if ( isNode ) { 
// 如果支持delete,就删除。 
// IE使用removeAttribute,所以尝试一次。再失败就只能设置为null了。 
if ( jQuery.support.deleteExpando ) { 
delete elem[ jQuery.expando ]; 
} else if ( elem.removeAttribute ) { 
elem.removeAttribute( jQuery.expando ); 
} else { 
elem[ jQuery.expando ] = null; 
} 
} 
}
Javascript 相关文章推荐
JavaScript Undefined,Null类型和NaN值区别
Oct 22 Javascript
javascript 对象定义方法 简单易学
Mar 22 Javascript
Jquery实现网页跳转或用命令打开指定网页的解决方法
Jul 09 Javascript
js选择并转移导航菜单示例代码
Aug 19 Javascript
jQuery 中$(this).index与$.each的使用指南
Nov 20 Javascript
深入解析AngularJS框架中$scope的作用与生命周期
Mar 05 Javascript
Javascript实现代码折叠功能
Aug 25 Javascript
js实现table添加行tr、删除行tr、清空行tr的简单实例
Oct 15 Javascript
JS函数修改html的元素内容,及修改属性内容的方法
Oct 28 Javascript
JS前端加密算法示例
Dec 22 Javascript
node全局变量__dirname与__filename的区别
Jan 14 Javascript
Vue-cli3简单使用(图文步骤)
Apr 30 Javascript
jQuery中的.bind()、.live()和.delegate()之间区别分析
Jun 08 #Javascript
jquery 跨域访问问题解决方法(笔记)
Jun 08 #Javascript
精通Javascript系列之数据类型 字符串
Jun 08 #Javascript
精通Javascript系列之Javascript基础篇
Jun 07 #Javascript
精通Javascript系列之数值计算
Jun 07 #Javascript
jQuery 源码分析笔记(4) Ready函数
Jun 02 #Javascript
在IE 浏览器中使用 jquery的fadeIn() 效果 英文字符字体加粗
Jun 02 #Javascript
You might like
S900/ ETON E1-XM 收音机
2021/03/02 无线电
php事务处理实例详解
2014/07/11 PHP
求解开jscript.encode代码的asp函数
2007/02/28 Javascript
jQuery对象的length属性用法实例
2014/12/27 Javascript
正则中的回溯定义与用法分析【JS与java实现】
2016/12/27 Javascript
bootstarp modal框居中显示的实现代码
2017/02/18 Javascript
JavaScript创建对象_动力节点Java学院整理
2017/06/27 Javascript
原生JS 购物车及购物页面的cookie使用方法
2017/08/21 Javascript
新手vue构建单页面应用实例代码
2017/09/18 Javascript
解决Jquery下拉框数据动态获取的问题
2018/01/25 jQuery
NodeJS简单实现WebSocket功能示例
2018/02/10 NodeJs
vue渲染时闪烁{{}}的问题及解决方法
2018/03/28 Javascript
150行Node.js实现的dns代理工具
2019/08/02 Javascript
原生js无缝轮播插件使用详解
2020/03/09 Javascript
vue-autoui自匹配webapi的UI控件的实现
2020/03/20 Javascript
在Python中使用__slots__方法的详细教程
2015/04/28 Python
Python内建数据结构详解
2016/02/03 Python
Python部署web开发程序的几种方法
2017/05/05 Python
python的exec、eval使用分析
2017/12/11 Python
Python实现计算圆周率π的值到任意位的方法示例
2018/05/08 Python
Python实现的多进程拷贝文件并显示百分比功能示例
2019/04/09 Python
pandas中DataFrame修改index、columns名的方法示例
2019/08/02 Python
解决Jupyter NoteBook输出的图表太小看不清问题
2020/04/16 Python
Python数据可视化实现漏斗图过程图解
2020/07/20 Python
python安装cx_Oracle和wxPython的方法
2020/09/14 Python
如何从csv文件构建Tensorflow的数据集
2020/09/21 Python
一款纯css3实现的圆形旋转分享按钮旋转角度可自己调整
2014/09/02 HTML / CSS
详解通过变换矩阵实现canvas的缩放功能
2019/01/14 HTML / CSS
使用canvas对多图片拼合并导出图片的方法
2018/08/28 HTML / CSS
ProBikeKit英国:在线公路自行车之家
2017/02/10 全球购物
Woods官网:加拿大最古老、最受尊敬的户外品牌之一
2020/09/12 全球购物
日语专业推荐信
2013/11/12 职场文书
关于运动会的稿件
2014/02/02 职场文书
团队激励口号
2014/06/06 职场文书
初中运动会前导词
2015/07/20 职场文书
当你找不到方向的时候,不妨读读刘备的一生
2019/08/05 职场文书