位置: 编程技术 - 正文

浅析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简单吗)

  • 个税抵扣申报晚好了需要跟公司申报吗?
  • 啥叫免抵税额
  • 作废的发票要拿出来吗
  • 财务往来账对账制度
  • 未发货先开票怎么结转成本
  • 公益机构可以收费吗
  • 员工自己承担的商业保险费是多少
  • 小规模建筑企业预缴税款
  • 购买的专利可以进费用吗
  • 股东变更没有公章和营业执照怎么办
  • 小规模都纳什么税
  • 应缴纳增值税计算公式
  • 考勤扣款是税前还是税后
  • 三八妇女节要求小班幼儿到校怎么分享
  • 税控盘清盘怎么做
  • 新金融工具准则投资收益
  • 汽车中介赚钱吗
  • 土地闲置费能否扣除
  • 两万元大写金额报销单怎么写
  • 投入资本公积需要结转吗
  • 发票在验旧日期之后作废吗
  • 会计基础工作是会计工作的基本环节
  • 鸿蒙实用工具在哪里
  • 苹果多屏协同win10
  • 赡养老人支出如果有四个子女都要填吗
  • pgptray.exe - pgptray是什么进程 有什么用
  • php 缓存
  • php随机一言
  • 拍卖有抵押的车子怎么处理
  • 转让居民企业的股权所得交企业所得税吗
  • 固定资产捐赠的账务处理
  • 小规模纳税人季报需要报什么
  • 基于MATLAB的车牌识别
  • vue如何实现登录
  • 《网络安全从入门到精通》
  • set命令用法
  • php改html
  • 织梦怎么调用当前栏目下的文章
  • 香港企业的所得税怎么算
  • 小企业会计准则和一般企业会计准则的区别
  • 被投资企业清算,长期股权投资处理
  • 综合所得计税依据
  • 恢复mysql数据库
  • 计提应交增值税怎么做账务处理
  • 外购的商品用于生产经营
  • 累计预扣法利弊
  • 库存现金银行存款用什么凭证
  • 增值税在实际计算时采取什么方法
  • 受托代销商品款是什么意思
  • 长期股权投资收回账务处理
  • 新政府会计固定资产的核算与计量
  • 公司收到某人打款怎么做分录
  • 购买国家机关证件罪量刑标准
  • 保险公司收车船税返还手续费犯罪
  • 接受代销货物的会计分录
  • 递延收益的会计核算
  • 哪些单位需要缴纳残疾人保障金
  • sql server 性能调优
  • win8开机logo
  • 复制电脑系统
  • ubuntu20.04怎么用
  • vrvedp_m.exe是什么
  • Mac如何开启sip
  • linux系统中怎么创建目录
  • win10更新后安装包会自动删除吗
  • centos安装v2
  • cocos2d::DrawPrimitives和DrawNode分别实现画板功能
  • 安卓十游戏怎么玩
  • node+express+ejs制作简单页面上手指南
  • 判断文件是否存在 java
  • android studio ndk编程 配置
  • Jquery uploadify上传插件使用详解
  • 零基础学JavaScript
  • javascriptjs
  • javascript如何学
  • 税务公众电话
  • 税控普通发票
  • 重大税务违法案件一案双查标准
  • 房屋租赁税率是6还是9
  • 三门峡哪个小区是原火葬场
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设