웹 프론트엔드 JS 튜토리얼 Jquery의 $(selector).each()와 $.each()의 차이점에 대한 자세한 설명

Jquery의 $(selector).each()와 $.each()의 차이점에 대한 자세한 설명

Jun 16, 2017 pm 04:20 PM
jquery selector 차이점

우리는 모두 Jqurey에서 Each 함수를 사용해 보았고, Each()를 호출하는 두 가지 방법이 있다는 것을 모두 알고 있습니다. 하나는 $.each()를 통해 호출하는 것이고, 다른 하나는 $(selector).each(를 통해 호출하는 것입니다. ), 그러면 둘 사이의 차이점은 무엇입니까?

Jquery 소스 코드를 보면 $.each()가 핵심 구현이고 $(selector).each()가 $.each()가 호출되는 것을 알 수 있습니다. 먼저 $의 소스 코드를 분석해 보겠습니다. .each() (하단):

Each(obj, callback, args) 함수는 3개의 매개변수를 받습니다: obj - 탐색할 객체 또는 배열, callback - 탐색하고 실행할 콜백 함수 , args - 사용자가 지정한 배열(먼저 무시하세요).

jQuery에서 각 메소드의 구현은 호출 메소드를 사용합니다. 먼저 다음 예에서 배열의 효과는 동일합니다.

전화를 통해 방향을 변경할 수 있습니다.

var testCall = function(obj, callback){
    callback.call(obj, 1);
}
로그인 후 복사

testCall(["1. this의 포인팅을 변경합니다.", "2. this를 통해 내부적으로 함수를 호출할 수 있습니다."], function(index){ //call 메소드를 사용하면 의 첫 번째 매개변수에 직접 접근할 수 있습니다. this를 통해 호출된 객체입니다.
alert(this[index]); //2.this를 통해 함수를 호출할 수 있습니다. })

는 call 메소드를 사용하지 않으며 this를 사용하지 않습니다.

var test = function(obj, callback){
    callback(obj, 1);
}
로그인 후 복사

test(["1. this의 포인팅을 변경합니다.", "2. 함수 내부에서 this를 통해 함수를 호출할 수 있습니다."], function(index){ //호출 메서드를 사용하지 마세요. this를 사용하지 마세요.
alert(this[index ]); //undefine});

jQuery.each는 call로 수정된 this 지점이어야 합니다.

$.each([1,2,3], function (index, item) {    console.log({index:index,value:item,_this:this});
});/*
  Object {index: 0, value: 1, _this: Number}
  Object {index: 1, value: 2, _this: Number}
  Object {index: 2, value: 3, _this: Number}
*/
로그인 후 복사

jQuery 소스 코드를 보지 않아서 callback.call을 사용했습니다. 복사하려면 같은 방식으로 구현해야 합니다.

var each = function(arr, callback){
  for( var index = 0 ; index < arr.length ; index++ ){
    callback.call(arr[index], index, arr[index]);
  }
}
each([1,2,3], function (index, item) {
    console.log({index:index,value:item,_this:this});
});/*
  Object {index: 0, value: 1, _this: Number}
  Object {index: 1, value: 2, _this: Number}
  Object {index: 2, value: 3, _this: Number}
*/
로그인 후 복사

참고: call을 사용하지 않으면 콜백 함수에서 사용할 수 없습니다.

1. args가 없는 경우

  일반적으로 args는 일반적으로 사용되지 않으므로 if(args)가 설정된 경우의 상황, 즉 코드에서 회색 부분을 직접 살펴보겠습니다. 각각() 함수의 핵심 부분

if(isArray) {
      for(; i < length; i++) {
        value = callback.call(obj[i], i, obj[i]);
        if(value === false) { break; }
      }
    }
로그인 후 복사

순회하려는 객체가 배열 유형인 경우 다음 코드 블록을 입력하세요
  for loop배열의 각 요소를 순회한 다음 호출 메소드를 사용하여 실행합니다. obj[i].callback( i, obj[i]),
따라서 콜백 함수를 직접 작성할 때 jquery는 배열의 각 개체를 사용하여 콜백 함수를 실행한다는 점을 인식해야 합니다. 동시에 콜백 메서드 내부의 이 요소도 요소를 가리킵니다.
다음 줄은 콜백 함수가 값을 반환하는지 확인하는 것입니다. 배열의 루프.

전달한 객체도 순회할 수 있는 경우 코드는 위의 배열 순회와 동일합니다

else {
      for(i in obj) {
          value = callback.call(obj[i], i, obj[i]);
          if(value === false) { break; }
        }
    }
로그인 후 복사

객체를 전달하는 경우 for(x in y)를 사용하여 객체의 속성을 순회합니다,
 The 원칙은 위와 동일합니다. 속성으로 변경하면 됩니다.

2. args의 경우

세 번째 매개변수로 각각()을 호출할 때 다음 코드 블록을 입력하여 분석합니다.

 

if(isArray) {            
   for(; i < length; i++) {
     value = callback.apply(obj[i], args);                
     if(value === false) { break; }
            }
        } else {            
        for(i in obj) {
          value = callback.apply(obj[i], args);                
          if(value === false) { break; 
          }
        }
  }
로그인 후 복사

같은 방식으로 먼저 무엇을 탐색할지 결정합니다. 객체가 배열이고, 배열이라면 배열의 obj[i] 요소를 순회한 후 obj[i].callback(args)를 실행하세요

주의! 여기에 전달된 매개변수는 전달한 args 배열입니다. 이는 args 매개변수가 없는 것과 다릅니다. 즉, Each 함수를 호출하고 자체 배열 매개변수를 전달하는 경우 콜백
함수의 매개변수 목록은 다음과 같습니다. args 배열을 전달했습니다. 다른 모든 것에 대해서는 위와 동일합니다. $(selector).each(callback,args) 함수는 2개의 매개변수를 받습니다: callback - 순회하고 실행할 콜백 함수, args - 사용자가 지정한 배열. $.each() 함수를 이해하고 나면 $(selector).each는 간단합니다. 소스 코드를 열어보면 $(selector).each 내부에 $.each() 함수가 호출되는 것을 알 수 있습니다. 소스 코드는 다음과 같습니다.

each: function( callback, args ) {
      return jQuery.each( this, callback, args );
  },
로그인 후 복사

보시다시피 $.each()를 호출하면 obj 매개변수가 $(selector)로 작성됩니다. 이는 jquery

내부 개체

를 반환하는 jquery 선택기입니다.  요약: $.each()와 $(selector).each()의 차이점은 전자는 모든 개체 또는 배열을 순회할 수 있는 반면 후자는 jquery 선택기가 반환한 jquery 내부 개체를 순회한다는 것입니다. 더 강해지세요

위 내용은 Jquery의 $(selector).each()와 $.each()의 차이점에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 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)

C 언어에서 Char와 WCHAR_T의 차이 C 언어에서 Char와 WCHAR_T의 차이 Apr 03, 2025 pm 03:09 PM

C 언어에서 char와 wchar_t의 주요 차이점은 문자 인코딩입니다. char ascii를 사용하거나 ascii를 확장하고, wchar_t는 유니 코드를 사용합니다. Char는 1-2 바이트를 차지하고 WCHAR_T는 2-4 바이트를 차지합니다. Char는 영어 텍스트에 적합하며 WCHAR_T는 다국어 텍스트에 적합합니다. Char_t는 널리 지원되며, 컴파일러 및 운영 체제가 유니 코드를 지원하는지 여부에 따라 다릅니다. Char는 문자 범위가 제한되며 WCHAR_T는 더 큰 문자 범위를 가지며 특수 함수는 산술 작업에 사용됩니다.

멀티 스레딩과 비동기 C#의 차이 멀티 스레딩과 비동기 C#의 차이 Apr 03, 2025 pm 02:57 PM

멀티 스레딩과 비동기식의 차이점은 멀티 스레딩이 동시에 여러 스레드를 실행하는 반면, 현재 스레드를 차단하지 않고 비동기식으로 작업을 수행한다는 것입니다. 멀티 스레딩은 컴퓨팅 집약적 인 작업에 사용되며 비동기식은 사용자 상호 작용에 사용됩니다. 멀티 스레딩의 장점은 컴퓨팅 성능을 향상시키는 것이지만 비동기의 장점은 UI 스레드를 차단하지 않는 것입니다. 멀티 스레딩 또는 비동기식을 선택하는 것은 작업의 특성에 따라 다릅니다. 계산 집약적 작업은 멀티 스레딩을 사용하고 외부 리소스와 상호 작용하고 UI 응답 성을 비동기식으로 유지 해야하는 작업을 사용합니다.

C 언어 합계의 기능은 무엇입니까? C 언어 합계의 기능은 무엇입니까? Apr 03, 2025 pm 02:21 PM

C 언어에는 내장 합계 기능이 없으므로 직접 작성해야합니다. 합계는 배열 및 축적 요소를 가로 질러 달성 할 수 있습니다. 루프 버전 : 루프 및 배열 길이를 사용하여 계산됩니다. 포인터 버전 : 포인터를 사용하여 배열 요소를 가리키며 효율적인 합계는 자체 증가 포인터를 통해 달성됩니다. 동적으로 배열 버전을 할당 : 배열을 동적으로 할당하고 메모리를 직접 관리하여 메모리 누출을 방지하기 위해 할당 된 메모리가 해제되도록합니다.

숯과 서명되지 않은 숯의 차이점은 무엇입니까? 숯과 서명되지 않은 숯의 차이점은 무엇입니까? Apr 03, 2025 pm 03:36 PM

Char 및 Unsigned Char는 문자 데이터를 저장하는 두 가지 데이터 유형입니다. 주요 차이점은 음수 및 양수를 다루는 방법입니다. 음수 처리 : char는 부정확 한 char가 할 수없고 음수를 저장할 수 있습니다. 비트 모드 : char 가장 높은 비트는 기호, 부호없는 문자 부호 비트를 나타냅니다. 산술 연산 : char and signed char는 서명하고 서명되지 않은 유형이며, 산술 작업은 다릅니다. 호환성 : 문자와 서명되지 않은 숯

C 언어 기능의 기본 요구 사항은 무엇입니까? C 언어 기능의 기본 요구 사항은 무엇입니까? Apr 03, 2025 pm 10:06 PM

C 언어 기능은 코드 모듈화 및 프로그램 구축의 기초입니다. 그들은 선언 (함수 헤더)과 정의 (기능 본문)로 구성됩니다. C 언어는 값을 사용하여 기본적으로 매개 변수를 전달하지만 주소 패스를 사용하여 외부 변수를 수정할 수도 있습니다. 함수는 반환 값을 가질 수 있거나 가질 수 있으며 반환 값 유형은 선언과 일치해야합니다. 기능 명명은 낙타 또는 밑줄을 사용하여 명확하고 이해하기 쉬워야합니다. 단일 책임 원칙을 따르고 기능 단순성을 유지하여 유지 관리 및 가독성을 향상시킵니다.

H5와 미니 프로그램과 앱의 차이점 H5와 미니 프로그램과 앱의 차이점 Apr 06, 2025 am 10:42 AM

H5. 미니 프로그램과 앱의 주요 차이점은 다음과 같습니다. 기술 아키텍처 : H5는 웹 기술을 기반으로하며 미니 프로그램 및 앱은 독립적 인 응용 프로그램입니다. 경험과 기능 : H5는 가볍고 사용하기 쉽고 기능이 제한되어 있습니다. 미니 프로그램은 가벼우 며 상호성이 우수합니다. 앱은 강력하고 부드러운 경험이 있습니다. 호환성 : H5는 크로스 플랫폼 호환성이며 애플릿 및 앱은 플랫폼에 의해 제한됩니다. 개발 비용 : H5는 개발 비용이 낮고 중간 미니 프로그램 및 최고 앱이 있습니다. 적용 가능한 시나리오 : H5는 정보 표시에 적합하고 애플릿은 가벼운 응용 프로그램에 적합하며 앱은 복잡한 기능에 적합합니다.

C와 C#의 차이점과 연결은 무엇입니까? C와 C#의 차이점과 연결은 무엇입니까? Apr 03, 2025 pm 10:36 PM

C와 C#은 유사성이 있지만 완전히 다릅니다. C는 프로세스 지향, 수동 메모리 관리 및 시스템 프로그래밍에 사용되는 플랫폼 의존 언어입니다. C#은 데스크탑, 웹 응용 프로그램 및 게임 개발에 사용되는 객체 지향, 쓰레기 수집 및 플랫폼 독립 언어입니다.

PS에서 PDF를 내보내기위한 비밀번호 보호를 설정하는 방법 PS에서 PDF를 내보내기위한 비밀번호 보호를 설정하는 방법 Apr 06, 2025 pm 04:45 PM

Photoshop에서 암호로 보호 된 PDF를 내보내십시오 : 이미지 파일을 엽니 다. "파일"을 클릭하십시오. & gt; "수출"& gt; "PDF로 수출". "보안"옵션을 설정하고 동일한 비밀번호를 두 번 입력하십시오. "내보내기"를 클릭하여 PDF 파일을 생성하십시오.

See all articles