이 글은 주로 jQuery 소스 코드의 데이터 버퍼링에 대한 학습을 소개합니다. 이제 특정 참조 값을 가지고 있습니다. 필요한 친구들이 참조할 수 있습니다.
메모리 누수가 무엇인가요?
무엇인가요? 메모리 누수란 브라우저 프로세스에서 메모리 블록을 사용하거나 종료할 수 없다는 뜻인가요? 브라우저는 자동 가비지 수집을 사용하여 메모리를 관리하는데, 이는 이미 꽤 좋지만 여전히 버그가 있으므로 메모리 누수가 발생합니다.
일반적인 메모리 누수는 다음과 같습니다.
순환 참조
javascript 클로저
DOM 삽입
DOM 객체가 포함된 순환 참조는 대부분의 최신 주류 브라우저에서 발생합니다. 메모리 누수
// [1] var a = new Object(); var b = new Object(); a.r = b; b.r = a; // [2] var a = new Object(); a.r = a; // 循环引用很常见且大部分情况下是无害的,但当参与循环引用的对象中有DOM对象或者ActiveX对象时,循环引用将导致内存泄露。
이 DOM에서 제거되었지만 해당 요소를 참조하는 개체나 변수가 여전히 남아 있어 삭제할 수 없습니다. 이 상황은 브라우저를 새로 고치면 제거될 수 있습니다.
또 다른 상황은 DOM 개체와 JS 개체가 서로를 참조하는 경우입니다. 이는 새로 고쳐도 메모리가 줄어들지 않는 상황입니다. 이는 엄밀한 의미에서 메모리 누수입니다.
따라서 일상적인 실제 애플리케이션에서는 요소에 대한 일부 데이터를 캐시해야 하는 경우가 많으며 이러한 데이터는 DOM 요소와 밀접한 관련이 있는 경우가 많습니다. DOM 요소(노드)도 객체이기 때문에 DOM 요소의 속성을 직접 확장할 수 있습니다. 그러나 DOM 요소에 사용자 정의 속성을 추가하거나 너무 많은 데이터를 추가하면 메모리 누수가 발생할 수 있으므로 그렇게 하지 않도록 노력해야 합니다. 따라서 더 나은 솔루션은 낮은 결합 방법을 사용하여 DOM과 캐시 데이터를 연결하는 것입니다.
jquery의 버퍼링 메커니즘은 이 문제를 해결합니다.
아이디어:
dom 객체에 일부 사용자 정의 속성을 생성하기 때문에 js 객체 등에서 참조될 때 jquery 버퍼링 메커니즘이 발생할 수 있습니다. 여기서 사용하는 것은 DOM에 저장하려는 데이터를 저장하기 위해 jquery에 버퍼 객체 cache
를 만드는 것입니다. cache
来存放我们想要再DOM中保存的数据。
但是问题又来了,我们怎么实现对DOM元素于jquery中的cache
对象中的数据的映射呢?
我们首先再DOM对象上创建一个唯一性的属性,他是expando
的值。而expando
的值是一个字符串,'jquery'+date
,基本上可以保证这个属性再不同DOM的唯一性。
接着把每个结点的dom[expando]
`的值设为是一个自增长的id,保持全局的唯一性,既可以使用cache[id]
`就可以获取到对应的数据了。即id就好比是打开一个房间(DOM节点)的钥匙。 而每个元素的所有缓存都被放到了一个map映射里面,这样可以同时缓存多个数据。
总之,现在DOM元素上找到expando
cache
개체에 있는 데이터에 어떻게 매핑합니까?
먼저 DOM 개체에 expando
값인 고유 속성을 만듭니다. expando
의 값은 문자열 'jquery'+date
이며, 이는 기본적으로 DOM에 관계없이 이 속성의 고유성을 보장합니다.
그런 다음 각 노드의 dom[expando]
` 값을 자체 증가 ID로 설정하여 전역 고유성을 유지할 수도 있습니다. 해당 데이터를 얻으려면. 즉, id는 방(DOM 노드)을 여는 열쇠와 같습니다. 각 요소에 대한 모든 캐시는 맵에 배치되므로 여러 데이터를 동시에 캐시할 수 있습니다.
expando
에 해당하는 값이 UID인 DOM 요소에서 발견됩니다. 그런 다음 이 uid를 통해 데이터 버퍼 Cache 개체의 특정 데이터를 찾습니다.
var cache = { "uid1": { // DOM节点1缓存数据, "name1": value1, "name2": value2 }, "uid2": { // DOM节点2缓存数据, "name1": value1, "name2": value2 } // ...... };
var ele1 = $("#aaron"); var ele2 = $("#aaron"); ele1.data('a',1111); ele2.data('a',2222); show('第一组,通过$().data()的方式,只取到最后一个a值,之前的被覆盖') show(ele1.data('a')) // 2222 show(ele2.data('a')) // 2222 show() //=======第二组========= show('第二组,通过$.data的方式,取到2组b值,未覆盖') $.data(ele1,"b","1111") // 1111 $.data(ele2,"b","2222") // 2222 show($.data(ele1,"b")) show($.data(ele2,"b") ) function show(data) { if (arguments.length == 2) { var info = arguments[0] var data = arguments[1]; for (var key in data) { $("body").append('
위 내용은 jQuery 소스 코드의 데이터 버퍼링에 대해 알아보기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!