位置: 编程技术 - 正文

浅析jQuery 3.0中的Data(jquery1.11.3)

编辑:rootadmin

推荐整理分享浅析jQuery 3.0中的Data(jquery1.11.3),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:jquery3.6,jquery3.6,jquery3.5.1,jquery3.5.1,jquery3.5.1,jquery3.2.1,jquery3.6,jquery3.3.1,内容如对您有帮助,希望把文章链接给更多的朋友!

jQuery 3.0 在6月9日正式发布了,3.0 也被称为下一代的 jQuery。这个版本从年月开始,其中发布过一次beta 版(/1/,)和候选版(//)。一路走来,颇为不易。

一、Data浅析

jQuery 3.0 中的 Data 是内部使用的,定义为一个“类”。一共用它创建了两个对象,dataPriv 和 dataUser。Data 有 1 个对象属性(expando)和类属性(uid),有 6 个方法,如下

下面分别解读

1、Data.uid

这是一个从 1 开始用来自增的数字。

2、expando

由 jQuery.expando 和 uid 组合而成,它用来作为元素(如DOM元素)的key,是唯一的。jQuery.expando 的生成如下

即 'jQuery' + (版本号 + 随机数),然后把非数字的都去掉,比如

去掉非数字变为

jQuery 3.0 内部变量 dataPriv 和 dataUser 生成 expando 如下

第三部分是随机数,每次刷新都会变,其它部分的不变。

3、cache

cache 方法会给 owner 上绑定一个对象作为存储,owner 必须满足 acceptData 的,cache 会以 this.expando 为线索 key。owner 有两种,一中是DOM元素(nodeType为1和9),另一种则是普通的JS对象。诸如 文本节点(nodeType=3)、注释节点(nodeType=8) 一律不添加。

acceptData 的定义如下

acceptData 在 3.0 中一共有 3 处使用,分别为

Data 类的 cache 方法,为私有方法不提供给程序员使用。$.cleanData 方法,清空元素关联的所有缓存数据。为公开方法,但很少使用。该方法被用在 empty、html、replaceWith、remove 方法中。$().trigger 方法,主动派发事件,为公开方法。

如果是 DOM 元素,则直接使用点操作符赋值,如果是普通 JS 对象则使用 ES5 的 Object.defineProperty 方法,这也是 jQuery 3.0 会使用新 API 的体现。

转换成如下代码

cache 方法就是这样,传入 owner,只有第一次会 set ,返回 value (一个空对象),之后取到 value 后直接返回。

源码

4、set

上面的 cache 方法为 owner 建立一个以 expando 为 key 的空对象,后面所有的方法都围绕这个空对象来展开,这个空对象就被称为缓存对象,后面所有的数据都添加到它上面。set 就是给这个对象来添砖加瓦,set 每次都是先取回 cache ,再给其添加新的属性及数据。如果 data 是字符串,则以它为 key 添加,如果是对象,则遍历它添加。只需注意一点,横线连接符内部会被转成驼峰格式,这也是为了对 H5 data-xxx 的兼容 。

源码

5、get

get 简单至极,传 key 则从 cache 上取回该 key 的值,无则取回整个 cache。

源码

6、access

这个方法即时 getter,也是 setter,如此而已。

getter 条件

key 是 undefined,这时取整个 cachekey 是字符串且value 是undefined,这是取指定 key 的值

setter 条件

浅析jQuery 3.0中的Data(jquery1.11.3)

owner、key、value 这三个参数都传

源码

7、remove

清空绑定元素(owner)上面的缓存对象,依然需要先通过 this.expando 拿到 cache,如果传了 key 则删除指定key的值(key自身也被删除)。当然 jQuery API 保持已有的方便性,key 可以为一个数组,这样可以批量删除多个 key。如果 key 没传则将整个 cache 删除,这里区分了 DOM 和普通 JS 对象,DOM 对象使用undefined赋值,JS 对象则使用 delete。

源码

8、hasData

用来判断 owner 上是否有缓存数据,返回 true 或 false。

源码

二、Data在jQuery内部的使用

以上解读完了 Data 的所有方法,上面也提到 Data 类是在 jQuery 内部使用的,一共创建了它的两个对象:dataPriv 和 dataUser。

这两个对象在 3.0.0 中有着明确的分工,dataPriv 可以猜测到是 “data” 和 “private” 两个单词的组合后简写。即 dataPriv 是私有的用来服务 jQuery 内部方法,dataUser 用来服务那些公开给用户使用的方法。

下面看下这两个对象分布在哪些模块中使用。

完整版点击展开可查看

以上可以看到,除了“公共”,DataPriv 用在了 jQuery 的 队列、动画、事件等模块;dataUser 用在了数据缓存及dataAttr模块。

“公共” 是指这三个方法内都用到了 dataPriv 和 dataUser

$.hasData(elem)

用来判断 elem 上是否绑定了相关的数据缓存,返回 true 和false,只有 dataPriv 和 dataUser 上都没有才返回 false

源码

$.cleanData(elems)

清空 elem 上绑定的所有数据缓存,理所当然的需要同时清空 dataPriv 和 dataUser 上的。注意:虽然这个方法在公开暴露在了 $ 上, 但官网API上却没有该方法的介绍。另使用不当会造成严重后果,比如绑定了事件后(.on),调用该方法,绑定的事件将全部失效。因为会清空 dataPriv 内的所有数据。

cloneCopyEvent(src, dest)

这是一个内部方法,$.clone 会使用到它。克隆元素时除了会克隆node节点外,绑定在node上的数据也会被克隆过去。比如

把 elem 克隆给 cloneNode,此时 elem 上添加的事件 cloneNode 上也会有。

三、1.x.x 和 2.x.x 的比较

jQuery 1.x 系列 和 2.x 系列的版本对 数据缓存模块的实现差异还是很大的。大家可以对比我年的这篇文章

1. 缓存的数据结构

1.x (直到1..2) 缓存都是存储在 jQuery.cache 上的,2.x(包括3.x) 则使用了一个内部类 Data 做缓存,其主要用到了两个对象 dataPriv 和 dataUser。很明显 2.x 做的更好,它所有的缓存数据都是私有的,不会存在被误写的风险,而 1.x 的 jQuery.cache 是公开的,如果被误写(比如某个同学想当然的给$上添加一个cache对象)后果不堪设想。

2. jQuery._data

看到这个下划线就知道是私有的(约定式),在 1.x 中是仅在内部使用的,不提供给开发者。以 1..2 示例、这个方法被事件模块、队列模块、动画模块、setGlobalEval、cloneCopyEvent、fixCloneNodeIssues、domManip、showHide、defaultPrefilter、toggleClass 使用。3.x 则使用 dataPriv 和 dataUser 替代,大家可以对比看看。

(2/3).x 相比 1.x 明显更优,dataPriv 和 dataUser 是真正的私有的(封装的更好,更安全),比起 1.x 约定式的私有 jQuery._data。虽然 3.0.0 还保守的兼容了 jQuery._data,相信过不了多久的后续版本就会剔除。

3. 重构

1.x 以 $._data 为中心,以它来辅助实现其它 API, (2/3).x 以 dataPriv/dataUser 为中心来实现。(2/3).x 将代码重构后提取出了 Data 类,更加清晰。

以上所述是小编给大家介绍的jQuery 3.0中的Data的全部叙述,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对积木网网站的支持!

简单实现的JQuery文本框水印插件 采用JQuery实现文本框的水印效果非常容易,效果如下:代码片段,定义要应用水印效果的文本框的样式:.watermark{color:#cccccc;}将JavaScript代码封装成JQuery

jQuery.Callbacks()回调函数队列用法详解 本文实例讲述了jQuery.Callbacks()回调函数队列用法。分享给大家供大家参考,具体如下:1、jQuery.CallbacksThejQuery.Callbacks()function,introducedinversion1.7,returnsamulti

jQuery实例—选项卡的简单实现(js源码和jQuery) 分别利用javascript的源码和jQuery来实现一个简单的选项卡,对比各自的步骤。!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""

标签: jquery1.11.3

本文链接地址:https://www.jiuchutong.com/biancheng/386684.html 转载请保留说明!

上一篇:jQuery中的一些常见方法小结(推荐)(jquery技巧)

下一篇:简单实现的JQuery文本框水印插件(jquery简单吗)

  • 支付工资代扣个税会计科目
  • 购买车辆保险的现金流
  • 金蝶美金账户怎么开
  • 分公司没有业务季报怎么处理
  • 开了红字信息表当月怎么做账
  • 销售增长率在报表上怎么看出来
  • 金蝶k3审核过账在哪里
  • 居民企业参股外国企业信息报告填写
  • 合伙制创投企业
  • 商业企业销售化妆品
  • 总公司和分公司类型必须一样么
  • 来料加工企业的人工工资计入什么费用
  • 工业企业生产费用要素一般有哪些
  • 住宿发票专票可抵扣吗
  • 工程节点奖金
  • 融资租赁承租人和出租人的会计处理
  • 应付账款扣款怎么做账
  • 合同中的税费需要交税吗
  • 取得进项票当月未认证
  • 资产折旧摊销扣什么税
  • 小规模纳税人增值税优惠政策
  • 营业执照印花税是什么意思啊
  • 免抵退说
  • 混合销售行为的含义及税务处理
  • 对公账户钱怎么退回去
  • 税控系统全额抵扣增值税申报
  • 个体户财务负责人风险有哪些
  • 销售发票冲红的条件有哪些?
  • 店面转让出去收到的钱如何做账?
  • 零申报个税怎么补申报可以不罚款吗
  • 重分类不成功
  • 企业已确认销售收入的售出商品发生销售折让,且不属于
  • 公司固定资产一般谁负责
  • 税盘没反应
  • 在windows7的
  • 差额征税通俗理解
  • 出售应收债权属于收入吗
  • 金融公司呆账对当事人有什么影响
  • phppost提交json
  • 牙痛怎么办怎么治疗
  • php保存数据
  • 作废的发票对方钱能打出来吗
  • php随机ua
  • nvidia-smi failed to initialize
  • php封装数据库连接
  • php高级程序招聘
  • 投资公司如何注册勘察设计工程师证书
  • 其他权益工具投资公允价值变动怎么计算
  • 暂估入库多了怎么办
  • 以货换货账务怎么处理
  • 捐赠支出汇算清缴需要调增吗
  • 绩效工资交个人所得税吗
  • 初始化mysql命令
  • 个贷系统平账专户a户为啥扣钱
  • 母子公司可以合并吗
  • 一年的系统服务费多少钱
  • 商品库存明细账
  • mysql的基础知识
  • 新百伦588
  • Ubuntu14.4下Sublime Text 3无法输入中文解决方法
  • freebsd操作命令
  • vista starter
  • windows7怎么给电脑加密码
  • win7系统安装软件乱码
  • JavaScript数组添加元素
  • 详解杭州亚运会会徽和口号
  • Android游戏开发教程
  • Eclipse开发工具安装
  • jquery 下拉框变更事件
  • 用jQuery实现优酷首页轮播图
  • javascript基础书
  • 周炜老婆是干什么的
  • 个税app如何更改扣缴义务人
  • 棚改房办房产证用不用交费
  • 如果贸易后y产品的相对价格下降很大的话
  • 个人所得税完税证明在哪里查询打印
  • 税务局的人为什么那么拽
  • 杭州市电子税务局官网登录
  • 安徽高考实行什么模式
  • 重庆税务查询企业信息查询系统
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设