jQuery的实现原理的模拟代码 -2 数据部分


Posted in Javascript onAugust 01, 2010

这个数据当然要通过属性来进行存取,但是,有多个属性怎么办呢?,要定义多个属性吗?,属性的名字叫什么呢?会不会与其他的属性有冲突呢?
在 jQuery 中,针对 DOM 对象扩展的私有数据可以用一个对象来表示,多个数据就使用这个对象的多个属性来表示。为了能够通过 DOM 对象找到这个扩展数据对象,而不会与其他现有的属性冲突,在 jQuery 中通过 expando 这个常量表示扩展对象的属性名,这个 expando 的值是计算出来的。而这个属性的值就是用来找到扩展对象的键值。
例如,我们可以定义 expando 的值为 "jQuery1234" ,那么,我们可以为每个 DOM 对象增加这个名为 "jQuery1234" 的属性,这个属性的值可以是一个键,例如为 1000。
在 jQuery 对象上的 cache 用来保存所有对象扩展的对象,这个对象可以看作一个字典,属性名就是键值,所对应的值就是扩展数据对象。
也就是说,在 jQuery 对象的 cache 上,将会有一个 1000 的成员,这个成员引用的对象就是 1000 号 DOM 对象的私有扩展对象。1000 号成员的私有数据将被存在在这个对象上。
当一个 DOM 对象需要取得扩展数据的时候,首先通过对象的 expando 属性取得一个键值,然后通过这个键值到 jQuery.cache 中取得自己的扩展对象,然后在扩展对象上读写数据。

/// <reference path="jQuery-core.js" /> 
// 常用方法 
function now() { 
return (new Date).getTime(); 
} 
// 扩充数据的属性名,动态生成,避免与已有的属性冲突 
var expando = "jQuery" + now(), uuid = 0, windowData = {}; 
jQuery.cache = {}; 
jQuery.expando = expando; 
// 数据管理,可以针对 DOM 对象保存私有的数据,可以读取保存的数据 
jQuery.fn.data = function (key, value) { 
// 读取 
if (value === undefined) { 
return jQuery.data(this[0], key); 
} 
else { // 设置 
this.each( 
function () { 
jQuery.data(this, key, value); 
} 
); 
} 
} 
// 移除数据,删除保存在对象上的数据 
jQuery.fn.removeData = function (key) { 
return this.each(function () { 
jQuery.removeData(this, key); 
}) 
} // 为元素保存数据 
jQuery.data = function (elem, name, data) { // #1001 
// 取得元素保存数据的键值 
var id = elem[expando], cache = jQuery.cache, thisCache; 
// 没有 id 的情况下,无法取值 
if (!id && typeof name === "string" && data === undefined) { 
return null; 
} 
// Compute a unique ID for the element 
// 为元素计算一个唯一的键值 
if (!id) { 
id = ++uuid; 
} 
// 如果没有保存过 
if (!cache[id]) { 
elem[expando] = id; // 在元素上保存键值 
cache[id] = {}; // 在 cache 上创建一个对象保存元素对应的值 
} 
// 取得此元素的数据对象 
thisCache = cache[id]; 
// Prevent overriding the named cache with undefined values 
// 保存值 
if (data !== undefined) { 
thisCache[name] = data; 
} 
// 返回对应的值 
return typeof name === "string" ? thisCache[name] : thisCache; 
} 
// 删除保存的数据 
jQuery.removeData = function (elem, name) { // #1042 
var id = elem[expando], cache = jQuery.cache, thisCache = cache[id]; 
// If we want to remove a specific section of the element's data 
if (name) { 
if (thisCache) { 
// Remove the section of cache data 
delete thisCache[name]; 
// If we've removed all the data, remove the element's cache 
if (jQuery.isEmptyObject(thisCache)) { 
jQuery.removeData(elem); 
} 
} 
// Otherwise, we want to remove all of the element's data 
} else { 
delete elem[jQuery.expando]; 
// Completely remove the data cache 
delete cache[id]; 
} 
} 
// 检查对象是否是空的 
jQuery.isEmptyObject = function (obj) { 
// 遍历元素的属性,只有要属性就返回假,否则返回真 
for (var name in obj) { 
return false; 
} 
return true; 
} 
// 检查是否是一个函数 
jQuery.isFunction = function (obj) { 
var s = toString.call(obj); 
return toString.call(obj) === "[object Function]"; 
}

下面的脚本可以保存或者读取对象的扩展数据。
// 数据操作 
$("#msg").data("name", "Hello, world."); 
alert($("#msg").data("name")); 
$("#msg").removeData("name"); 
alert($("#msg").data("name"));
Javascript 相关文章推荐
jquery交替变换颜色的三种方法 实例代码
Nov 19 Javascript
javaScript中两个等于号和三个等于号之间的区别介绍
Jun 27 Javascript
javascript基本算法汇总
Mar 09 Javascript
基于BootStrap的图片轮播效果展示实例代码
May 23 Javascript
JavaScript中闭包之浅析解读(必看篇)
Aug 25 Javascript
js Canvas绘制圆形时钟教程
Feb 06 Javascript
jQuery简易时光轴实现方法示例
Mar 13 Javascript
详解为Bootstrap Modal添加拖拽的方法
Jan 05 Javascript
vue项目使用微信公众号支付总结及遇到的坑
Oct 23 Javascript
解决vue单页面修改样式无法覆盖问题
Aug 05 Javascript
js实现点击图片在屏幕中间弹出放大效果
Sep 11 Javascript
javscript 数组扁平化的实现
Feb 03 Javascript
jQuery的实现原理的模拟代码 -1 核心部分
Aug 01 #Javascript
jQuery validate 中文API 附validate.js中文api手册
Jul 31 #Javascript
jQuery对象[0]是什么含义?
Jul 31 #Javascript
动态调用CSS文件的JS代码
Jul 29 #Javascript
date.parse在IE和FF中的区别
Jul 29 #Javascript
iframe自适应宽度、高度 ie6 7 8,firefox 3.86下测试通过
Jul 29 #Javascript
jquery中对表单的基本操作代码
Jul 29 #Javascript
You might like
PHP概述.
2006/10/09 PHP
如何在symfony中导出为CSV文件中的数据
2011/10/06 PHP
php正则表达式使用方法整理集合
2020/01/31 PHP
ThinkPHP5分页paginate代码实例解析
2020/11/10 PHP
Javascript之文件操作
2007/03/07 Javascript
你需要知道的10个最佳javascript开发实践小结
2012/04/15 Javascript
jquery和javascript的区别(常用方法比较)
2013/07/04 Javascript
Js放到HTML文件中的哪个位置有什么区别
2013/08/21 Javascript
由浅入深讲解Javascript继承机制与simple-inheritance源码分析
2015/12/13 Javascript
jquery中的常见问题及快速解决方法小结
2016/06/14 Javascript
JS简单实现tab切换效果的多窗口显示功能
2016/09/07 Javascript
jQuery简单创建节点的方法
2016/09/09 Javascript
深入理解JavaScript中的块级作用域、私有变量与模块模式
2016/10/31 Javascript
BootStrap table使用方法分析
2016/11/08 Javascript
jQuery实现圣诞节礼物动画案例解析
2016/12/25 Javascript
详解Angular的双向数据绑定(MV-VM)
2016/12/26 Javascript
JavaScript原生编写《飞机大战坦克》游戏完整实例
2017/01/04 Javascript
Bootstarp 基础教程之表单部分实例代码
2017/02/03 Javascript
angularjs实现天气预报功能
2020/06/16 Javascript
vue2.0安装style/css loader的方法
2018/03/14 Javascript
iview的table组件自带的过滤器实现
2019/07/12 Javascript
200行自定义python异步非阻塞Web框架
2017/03/15 Python
Python复数属性和方法运算操作示例
2017/07/21 Python
PyQt5实现五子棋游戏(人机对弈)
2020/03/24 Python
基于python分析你的上网行为 看看你平时上网都在干嘛
2019/08/13 Python
python生成器/yield协程/gevent写简单的图片下载器功能示例
2019/10/28 Python
Python完全识别验证码自动登录实例详解
2019/11/24 Python
Python数据相关系数矩阵和热力图轻松实现教程
2020/06/16 Python
运动会通讯稿300字
2014/02/02 职场文书
销售会计岗位职责
2014/03/15 职场文书
技术比武方案
2014/05/19 职场文书
师德师风剖析材料
2014/09/30 职场文书
高中开学感言
2015/08/01 职场文书
MySQL锁机制
2021/04/05 MySQL
python使用pygame创建精灵Sprite
2021/04/06 Python
深入理解以DEBUG方式线程的底层运行原理
2021/06/21 Java/Android