웹 프론트엔드 JS 튜토리얼 Jquery의 핵심 기능에 대한 심층 분석

Jquery의 핵심 기능에 대한 심층 분석

Jun 17, 2017 pm 05:49 PM
jquery 깊이 분석하다

핵심 기능은 다음과 같습니다:

jquery 정의 방법, 호출 방법 및 확장 방법. 핵심 메소드가 어떻게 구현되는지 마스터하는 것이 jQuery 소스 코드를 이해하는 열쇠입니다. 여기서 모든 것이 갑자기 명확해집니다.

1, 정의하는 방법, 즉 입구

// jQuery의 로컬 복사본 정의

var jQuery = function( selector, context ) {

// jQuery 객체는 실제로는 단지 init 생성자입니다 ' Enhanced'

Return new jQuery.fn.init(selector, context, rootjQuery);//jQuery 객체는 jQuery의 프로토타입인 jQuery.prototype.init}

2의

constructor향상된 버전일 뿐입니다. , jQuery.fn .init

//객체 메소드 정의의 관계, 즉 $("xx")를 통해서만 호출할 수 있습니다.

jQuery.fn = jQuery.prototype = {

init:function( selector, context, rootjQuery ) {

return jQuery.makeArray( selector, this );

}

그 밖에도 많은 속성과 메서드가 있습니다 ,

속성은 다음과 같습니다: jquery, constructor, selector, length

메서드는 다음과 같습니다: toArray, get, pushStack, Each, Ready, Slice, first, last, eq, map, end, push, sort, splice

}

//나중 인스턴스화를 위해 init 함수에 jQuery 프로토타입 제공

jQuery.fn.init.prototype = jQuery .fn;

즉, $("xx")에는 인스턴스 메서드가 있으며 호출될 수 있습니다. . (jQuery.prototype에 정의된 메소드 호출)

jQuery는 왜 jQuery.fn.init 객체를 반환하나요?

jQuery = function( selector, context ) {

// jQuery 객체는 실제로는 'init 생성자'입니다. '

return new jQuery.fn.init( selector, context, rootjQuery );

}

jQuery.fn = jQuery.prototype = {



}

jQuery.fn.init.prototype = jQuery. fn;

Stackoverflow에서 비슷한 질문을 찾아보세요:

http://stackoverflow.com/questions/4754560/help-understanding-jquerys-jquery-fn-init-why-is-init-in-fn

또한 이것

http://stackoverflow.com/questions/1856890/why-does-jquery-use-new-jquery-fn-init-for-creating-jquery-object-but-i-can/1858537#1858537

나는 믿습니다 코드는 새로운 jQuery 개체를 인스턴스화할 때마다 new 키워드가 필요하지 않고 개체 구성 뒤에 있는 논리를 프로토타입에 위임하도록 이러한 방식으로 작성됩니다. 후자는 초기화 논리를 한 곳에 깔끔하게 유지하고 init를 재귀적으로 호출하여 전달된 인수와 올바르게 일치하는 객체를 구성하고 반환할 수 있도록 합니다.

3, 확장 객체 메서드 및 정적 메서드 원칙을 확장

jQuery .extend = jQuery.fn.extend = function() {

var target = 인수[0] || {};

return target;

}

$.extend에 지나지 않는 확장을 사용하는 것이 편리합니다. ({ }); 그리고 $.fn.extend({}); fn을 볼 때 jQuery.prototype을 이해하고 생각해 보면 좋을 것 같습니다.

이 범위를 다시 살펴보세요.

$.extend ->이것은 $-> this.aa()

$.fn.extend->이것은 $.fn-> )

첨부된 확장 구현 세부정보:

사용 시나리오:

1, 단 하나의 매개변수로 일부 기능을

확장합니다. 예: $.extend({f1:function(){},f2:function(){},f3:function(){}})

2, 여러 객체를 첫 번째 객체로 병합

(1) 얕은 copy에서 첫 번째 매개변수는 대상 객체입니다. 예를 들어

var a = {이름:”안녕하세요”}

var b = {나이:30}

$.extend(a,b);//a={이름:"안녕하세요",나이:30}

(2) Deep Copy, 첫 번째 매개변수는 TRUE, 두 번째 매개변수는 대상 객체입니다. 예를 들어

var a = {이름:{job:”it”}};

var b = {이름:{age: 30 }};

//$.extend(a,b);

$ .extend(true,a,b);

console.log(a);

jQuery.extend = jQuery.fn.extend = function() {
    var options, name, src, copy, copyIsArray, clone,
        target = arguments[0] || {},
        i = 1,
        length = arguments.length,
        deep = false;

    // 是不是深复制  Handle a deep copy situation
    if ( typeof target === "boolean" ) {
        deep = target;
        target = arguments[1] || {};
        // skip the boolean and the target
        i = 2;
    }

    // 不是对象类型  Handle case when target is a string or something (possible in deep copy)
    if ( typeof target !== "object" && !jQuery.isFunction(target) ) {
        target = {};
    }

    // 扩展插件的情况  extend jQuery itself if only one argument is passed
    if ( length === i ) {//$.extend({f1:function(){},f2:function(){},f3:function(){}})
        target = this;//this是$,或是$.fn
        --i;
    }

    for ( ; i < length; i++ ) {//可能有多个对象扩展到第一个对象上
        // Only deal with non-null/undefined values
        if ( (options = arguments[ i ]) != null ) {//options是一个对象
            // Extend the base object
            for ( name in options ) {
                src = target[ name ];  //src是target里已经存在的value(也可能不存在)
                copy = options[ name ];//copy是待合入的一个value

                // 防止循环引用  Prevent never-ending loop
                if ( target === copy ) {//例如:var a={};$.extend(a,{name:a});//可能导致循环引用
                    continue;
                }

                // if是深复制else是浅复制  Recurse if we're merging plain objects or arrays
                if ( deep && copy && ( jQuery.isPlainObject(copy) || (copyIsArray = jQuery.isArray(copy)) ) ) {
                    if ( copyIsArray ) {
                        copyIsArray = false;
                        clone = src && jQuery.isArray(src) ? src : [];

                    } else {
                        clone = src && jQuery.isPlainObject(src) ? src : {};
                    }

                    // 亮了,直至剥离至最深一层非对象类型,而且是逐个。Never move original objects, clone them
                    target[ name ] = jQuery.extend( deep, clone, copy );

                // Don't bring in undefined values
                } else if ( copy !== undefined ) {
                    target[ name ] = copy;//target[ name ] = options[ name ];
                }
            }
        }
    }

    // Return the modified object
    return target;
};
로그인 후 복사

jQuery.extend({…}) 분석

작성 방법을 살펴보세요

jQuery.extend({

prop : ””

method:function(){}

});

이러한 메소드는 jQuery의 정적 속성이자 메소드(즉, 도구 메소드)임을 알 수 있습니다. 사용자 또는 내부용.

구체적으로 구현된 도구 속성 및 메소드는 (내부적으로 사용되는 속성 및 메소드도 표시되어 있습니다)

jQuery.extend({

                                                                                                                                     Wait : 기다릴 파일 수에 대한 카운터(내부) HoldReady(): DOM 트리거를 소진합니다.

Ready(): DOM 트리거를 준비합니다.

isfunction(): 여부 function

Isarray(): 배열인가요? ): 디지털 p인지 여부 Type(): 판단
데이터 유형


iSplainObject(): 객체 독립적인가요?
         parseHTML()                                                                                                           () : 글로벌 분석 JS

camelCase() : Camel Case 변환

nodeName() : 지정된 노드 이름인지 여부(내부)

Each() : 컬렉션 순회

Trim() : 앞뒤 공백 제거
makeArray( ) : 클래스 배열을 실제 배열로 변환
inArray() : Number Group 버전 indexOf
​​​이를

을 가리키도록 변경 access() : 다기능 값 연산(내부)

now() : 현재 시간 swap () : CSS swap (내부)

});

jQuery.ready.promise = function(){}; DOM의 비동기 작업 모니터링(내부)

function isArraylike(){} 배열과 같은 판단(내부)

위 내용은 Jquery의 핵심 기능에 대한 심층 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Oracle 오류 3114에 대한 자세한 설명: 신속하게 해결하는 방법 Oracle 오류 3114에 대한 자세한 설명: 신속하게 해결하는 방법 Mar 08, 2024 pm 02:42 PM

Oracle 오류 3114에 대한 자세한 설명: 이를 신속하게 해결하는 방법, 구체적인 코드 예제가 필요합니다. Oracle 데이터베이스를 개발 및 관리하는 동안 다양한 오류가 발생하는 경우가 많으며 그중 오류 3114는 비교적 일반적인 문제입니다. 오류 3114는 일반적으로 네트워크 오류, 데이터베이스 서비스 중지 또는 잘못된 연결 문자열 설정으로 인해 발생할 수 있는 데이터베이스 연결 문제를 나타냅니다. 이 문서에서는 오류 3114의 원인과 이 문제를 신속하게 해결하는 방법을 자세히 설명하고 특정 코드를 첨부합니다.

PHP에서 중간점의 의미와 사용법 분석 PHP에서 중간점의 의미와 사용법 분석 Mar 27, 2024 pm 08:57 PM

[PHP 중간점의 의미와 사용법 분석] PHP에서 중간점(.)은 두 개의 문자열이나 객체의 속성이나 메소드를 연결하는 데 사용되는 일반적으로 사용되는 연산자입니다. 이 기사에서는 구체적인 코드 예제를 통해 PHP에서 중간점의 의미와 사용법을 자세히 살펴보겠습니다. 1. 문자열 중간점 연산자 연결 PHP에서 가장 일반적인 사용법은 두 문자열을 연결하는 것입니다. 두 문자열 사이에 .을 배치하면 두 문자열을 이어붙여 새 문자열을 만들 수 있습니다. $string1=&qu

웜홀 NTT 구문 분석: 모든 토큰을 위한 개방형 프레임워크 웜홀 NTT 구문 분석: 모든 토큰을 위한 개방형 프레임워크 Mar 05, 2024 pm 12:46 PM

Wormhole은 블록체인 상호 운용성의 선두주자로서 소유권, 통제 및 무허가형 혁신을 우선시하는 탄력적이고 미래 지향적인 분산 시스템을 만드는 데 중점을 두고 있습니다. 이 비전의 기초는 단순성, 명확성 및 광범위한 다중 체인 솔루션 제품군으로 상호 운용성 환경을 재정의하기 위한 기술 전문 지식, 윤리적 원칙 및 커뮤니티 조정에 대한 헌신입니다. 영지식 증명, 확장 솔루션 및 풍부한 기능의 토큰 표준이 등장하면서 블록체인은 더욱 강력해지고 상호 운용성은 점점 더 중요해지고 있습니다. 이 혁신적인 애플리케이션 환경에서 새로운 거버넌스 시스템과 실용적인 기능은 네트워크 전반의 자산에 전례 없는 기회를 제공합니다. 프로토콜 빌더는 이제 이 새로운 멀티체인에서 어떻게 기능할지 고민하고 있습니다.

Win11의 새로운 기능 분석: Microsoft 계정 로그인을 건너뛰는 방법 Win11의 새로운 기능 분석: Microsoft 계정 로그인을 건너뛰는 방법 Mar 27, 2024 pm 05:24 PM

Win11의 새로운 기능 분석: Microsoft 계정 로그인을 건너뛰는 방법 Windows 11이 출시되면서 많은 사용자는 Windows 11이 더 편리하고 새로운 기능을 제공한다는 사실을 알게 되었습니다. 그러나 일부 사용자는 시스템을 Microsoft 계정에 연결하는 것을 좋아하지 않아 이 단계를 건너뛰기를 원할 수도 있습니다. 이 문서에서는 사용자가 Windows 11에서 Microsoft 계정 로그인을 건너뛰고 보다 개인적이고 자율적인 환경을 달성하는 데 도움이 되는 몇 가지 방법을 소개합니다. 먼저 일부 사용자가 Microsoft 계정에 로그인하기를 꺼리는 이유를 이해해 보겠습니다. 한편으로는 일부 사용자들은 다음과 같은 걱정을 합니다.

jQuery 팁: 페이지에 있는 모든 태그의 텍스트를 빠르게 수정하세요. jQuery 팁: 페이지에 있는 모든 태그의 텍스트를 빠르게 수정하세요. Feb 28, 2024 pm 09:06 PM

제목: jQuery 팁: 페이지에 있는 모든 태그의 텍스트를 빠르게 수정하세요. 웹 개발에서는 페이지의 요소를 수정하고 조작해야 하는 경우가 많습니다. jQuery를 사용할 때 페이지에 있는 모든 태그의 텍스트 내용을 한 번에 수정해야 하는 경우가 있는데, 이는 시간과 에너지를 절약할 수 있습니다. 다음은 jQuery를 사용하여 페이지의 모든 태그 텍스트를 빠르게 수정하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 먼저 jQuery 라이브러리 파일을 도입하고 다음 코드가 페이지에 도입되었는지 확인해야 합니다. &lt

jQuery를 사용하여 모든 태그의 텍스트 내용 수정 jQuery를 사용하여 모든 태그의 텍스트 내용 수정 Feb 28, 2024 pm 05:42 PM

제목: jQuery를 사용하여 모든 태그의 텍스트 내용을 수정합니다. jQuery는 DOM 작업을 처리하는 데 널리 사용되는 인기 있는 JavaScript 라이브러리입니다. 웹 개발을 하다 보면 페이지에 있는 링크 태그(태그)의 텍스트 내용을 수정해야 하는 경우가 종종 있습니다. 이 기사에서는 jQuery를 사용하여 이 목표를 달성하는 방법을 설명하고 구체적인 코드 예제를 제공합니다. 먼저 페이지에 jQuery 라이브러리를 도입해야 합니다. HTML 파일에 다음 코드를 추가합니다.

Apache2는 PHP 파일을 올바르게 구문 분석할 수 없습니다. Apache2는 PHP 파일을 올바르게 구문 분석할 수 없습니다. Mar 08, 2024 am 11:09 AM

공간 제한으로 인해 다음은 간략한 기사입니다. Apache2는 일반적으로 사용되는 웹 서버 소프트웨어이고 PHP는 널리 사용되는 서버측 스크립팅 언어입니다. 웹 사이트를 구축하는 과정에서 Apache2가 PHP 파일을 올바르게 구문 분석할 수 없어 PHP 코드가 실행되지 않는 문제가 발생하는 경우가 있습니다. 이 문제는 일반적으로 Apache2가 PHP 모듈을 올바르게 구성하지 않거나 PHP 모듈이 Apache2 버전과 호환되지 않기 때문에 발생합니다. 이 문제를 해결하는 방법은 일반적으로 두 가지가 있는데, 그 중 하나는

XML 구문 분석을 위한 Java 라이브러리 비교: 최상의 솔루션 찾기 XML 구문 분석을 위한 Java 라이브러리 비교: 최상의 솔루션 찾기 Mar 09, 2024 am 09:10 AM

소개 XML(Extensible Markup Language)은 데이터 저장 및 전송에 널리 사용되는 형식입니다. Java에서 XML을 구문 분석하는 것은 데이터 교환에서 문서 처리에 이르기까지 많은 응용 프로그램에 필요한 작업입니다. XML을 효율적으로 구문 분석하기 위해 개발자는 다양한 Java 라이브러리를 사용할 수 있습니다. 이 기사에서는 가장 널리 사용되는 XML 구문 분석 라이브러리 중 일부를 특징, 기능 및 성능에 중점을 두고 비교하여 개발자가 현명한 선택을 할 수 있도록 돕습니다. DOM(문서 개체 모델) 구문 분석 라이브러리 JavaXMLDOMAPI: Oracle에서 제공하는 표준 DOM 구현입니다. 개발자가 XML 문서에 액세스하고 조작할 수 있는 개체 모델을 제공합니다. DocumentBuilderFactoryfactory=D

See all articles