이 글은 주로 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의 버퍼링 메커니즘은 이 문제를 해결합니다.
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

实现方法:1、用“$("img").delay(毫秒数).fadeOut()”语句,delay()设置延迟秒数;2、用“setTimeout(function(){ $("img").hide(); },毫秒值);”语句,通过定时器来延迟。

修改方法:1、用css()设置新样式,语法“$(元素).css("min-height","新值")”;2、用attr(),通过设置style属性来添加新样式,语法“$(元素).attr("style","min-height:新值")”。

区别:1、axios是一个异步请求框架,用于封装底层的XMLHttpRequest,而jquery是一个JavaScript库,只是顺便封装了dom操作;2、axios是基于承诺对象的,可以用承诺对象中的方法,而jquery不基于承诺对象。

增加元素的方法:1、用append(),语法“$("body").append(新元素)”,可向body内部的末尾处增加元素;2、用prepend(),语法“$("body").prepend(新元素)”,可向body内部的开始处增加元素。

在jquery中,apply()方法用于改变this指向,使用另一个对象替换当前对象,是应用某一对象的一个方法,语法为“apply(thisobj,[argarray])”;参数argarray表示的是以数组的形式进行传递。

删除方法:1、用empty(),语法“$("div").empty();”,可删除所有子节点和内容;2、用children()和remove(),语法“$("div").children().remove();”,只删除子元素,不删除内容。

去掉方法:1、用“$(selector).removeAttr("readonly")”语句删除readonly属性;2、用“$(selector).attr("readonly",false)”将readonly属性的值设置为false。

on()方法有4个参数:1、第一个参数不可省略,规定要从被选元素添加的一个或多个事件或命名空间;2、第二个参数可省略,规定元素的事件处理程序;3、第三个参数可省略,规定传递到函数的额外数据;4、第四个参数可省略,规定当事件发生时运行的函数。


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

드림위버 CS6
시각적 웹 개발 도구

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

안전한 시험 브라우저
안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.
