jQuery数据缓存方案详解:$.data()的使用

jQuery提供了一种优雅的数据缓存方案,通过$.data()、$.cache、$.expando、$.hasData()和$.removeData()等方法,避免了全局变量的命名污染和DOM操作的性能损耗。$.hasData()用于检查对象是否有附加属性,$.data()用于读写属性值,而$.removeData()用于释放内存。jQuery.expando是一个随机字符串,作为对象的属性名。了解这些,能更好地利用jQuery进行数据管理。
摘要由CSDN通过智能技术生成

我们经常使用隐藏控件或者是js全局变量来临时存储数据,全局变量容易导致命名污染,隐藏控件导致经常读写dom浪费性能。jQuery提供了自己的数据缓存方案,能够达到和隐藏控件、全局变量相同的效果,但是jQuery实现方式更优雅。为了更好地使用jQuery数据缓存方案,我们需要掌握$.data()、$.cache、$.expando、$.hasData()、$.removeData()。


$.hasData()用来判断某个对象是否有附加的属性,可以给任何javascript对象和HTMLElement对象附加属性。$.data()用来读取或者修改属性值。$.removeData()用来删除已经添加的属性,这是为了释放内存,避免过多无用属性浪费内存。

var myObj = {};
// hasData用来判断HTMLElement或JS对象是否具有数据
console.log(jQuery.hasData($("#a")));// false

// data()添加属性
$.data(myObj, 'name', 'aty');
console.log(jQuery.hasData(myObj));// true

// data()读取属性
console.log($.data(myObj, 'name'));//aty

// removeData删除属性
$.removeData(myObj, 'name');
console.log($.data(myObj, 'name'));//undefined

// 如果所有属性都被删除,那么hasData返回false
console.log(jQue
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值