jQuery教程:data()方法避免内存泄露问题

dthylwl

dthylwl

2016-02-20 01:06

今天图老师小编要向大家分享个jQuery教程:data()方法避免内存泄露问题教程,过程简单易学,相信聪明的你一定能轻松get!

jQuery的官方文档中,提示用户这是一个低级的方法,应该用.data()方法来代替。$.data( element, key, value )可以对DOM元素附加任何类型的数据,但应避免循环引用而导致的内存泄漏问题,原文如下:

The jQuery.data() method allows us to attach data of any type to DOM elements in a way that is safe from circular references and therefore from memory leaks. We can set several distinct values for a single element and retrieve them later:

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

但对于该方法,存在的问题也不仅于此。在JQUERY FORUM中 ,对该问题作了深入的讨论,robert.katic 提出了一条解决方案。$.data()方法应用到宿主对象上,运行会得到优化,但在本地对像上使用该方法,结果未必尽如人意。一个元素在正常情况下可以使用.remove()方法将其删除,并清除各自的数据。但对于本地对象而言,这是不能彻底删除的,这些相关的数据一直持续到窗口对象关闭。同样,这些问题也存在于event 对象中,因为事件处理器(handlers)也是用该方法来存储的。

那么,要解决该问题最简单的方法是将数据存储到本地对象新增的一个属性之中。即:

// ...
if ( elem.nodeType ) { 
        cache[ id ] = dataObject; 
        elem[ expando ] = id;
} else { 
        elem[ expando ] = dataObject;
}
// ...

但是,一旦涉及到继承问题,该方法就无能为力。试看:

var parent = {};
var childA = Object.create( parent );
var childB = Object.create( parent ); 
 
$.data( parent, "foo", "parent value" ); 
 
// This may even be intentional
$.data( childA, "foo" ) 
// = "parent value"
$.data( childB, "foo" ) 
// = "parent value" 
 
// This may NOT be intentional
$.data( childA, "foo", "childA value" );
$.data( parent, "foo" ) 
// = "childA value"
$.data( childB, "foo" ) 
// = "childA value"

开始时,存储数据的对象不存在,因此创建一个对象来存储新的值,如图

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

现在,我们尝试去修改对象childA同样的数据。

对象childA并不存在该数据,因此它沿着原型链向上查找,父对象刚好拥有该数据,其值立即被改写。所以,从parent和childB这两个对象获取foo的值,得到的将是childA value,而不是parent value。

展开更多 50%)
分享

猜你喜欢

jQuery教程:data()方法避免内存泄露问题

Web开发
jQuery教程:data()方法避免内存泄露问题

Java内存泄露问题分析

Java JAVA基础
Java内存泄露问题分析

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

内存泄露检查

编程语言 网络编程
内存泄露检查

VC内存泄露检查工具:VisualLeakDetector

服务器
VC内存泄露检查工具:VisualLeakDetector

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

详细介绍Java内存泄露原因

编程语言 网络编程
详细介绍Java内存泄露原因

权威JavaScript 中的内存泄露模式

Web开发
权威JavaScript 中的内存泄露模式

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

打开EXCEL时无法找到startup.xls文件的解决方法

打开EXCEL时无法找到startup.xls文件的解决方法

什么是JavaScript框架

什么是JavaScript框架
下拉加载更多内容 ↓