>웹 프론트엔드 >JS 튜토리얼 >jquery의 $each() 메소드 사용 안내

jquery의 $each() 메소드 사용 안내

巴扎黑
巴扎黑원래의
2017-07-09 11:11:50922검색

jQuery의 각 함수는 매우 편리합니다. $.each() 함수는 1차원 배열, 다차원 배열, DOM, JSON 등을 탐색할 수 있는 매우 강력한 순회 함수를 캡슐화합니다. JavaScript 개발 프로세스 각각은 작업량을 크게 줄일 수 있습니다. 다음은 배열 유형 객체만 처리할 수 있는 각각을 모방하는 간단한 함수입니다.

$.each()는 $(selector).each()와 다릅니다. 후자는 jquery 객체를 탐색하는 데 특별히 사용됩니다(배열이든 객체이든). 배열입니다, 콜백 함수 배열의 인덱스와 해당 값이 전달될 때마다(값은 this 키워드를 통해서도 얻을 수 있지만 JavaScript는 항상 이 값을 객체로 래핑합니다. 문자열 또는 숫자), 메소드는 순회된 객체를 반환합니다. 의 첫 번째 매개변수

each() 메소드는 DOM 루프 구조를 간결하게 만들고 오류가 발생할 가능성을 줄입니다. Each() 함수는 매우 강력한 순회 함수를 캡슐화하고 사용하기가 매우 편리합니다. 1차원 배열, 다차원 배열, DOM, JSON 등을 순회할 수 있습니다. JavaScript 개발 프로세스 중에 $each를 사용하면 작업 부하를 크게 줄일 수 있습니다. .


다음은

each

각각의 1차원 배열 처리

var arr1 = [ "aaa", "bbb", "ccc" ]; 
$.each(arr1, function(i,val){ 
alert(i); 
alert(val);
});

alert(i)의 몇 가지 일반적인 용도입니다. 0, 1, 2를 출력합니다.

alert(val)는 aaa, bbb, ccc를 출력합니다.


각 프로세스는

2차원 배열

  var arr2 = [['a', 'aa', 'aaa'], ['b', 'bb', 'bbb'], ['c', 'cc', 'ccc']] 
  $.each(arr, function(i, item){ 
alert(i); 
alert(item); 
  });

arr2을 2차원 배열로 하고, item은 이 2차원 배열의 각 배열을 취하는 것과 동일합니다.

item[0]은 각 1차원 배열의 첫 번째 값을 기준으로

alert(i)는 0, 1, 2를 출력합니다. 이 2차원 배열에는 3개의 배열 요소가 포함되어 있기 때문입니다.
alert(item)은 For [' a', 'aa', 'aaa'], ['b', 'bb', 'bbb'], ['c', 'cc', 'ccc']

이 두 자리 배열의 경우 처리 변경

var arr = [['a', 'aa', 'aaa'], ['b', 'bb', 'bbb'], ['c', 'cc', 'ccc']] 
  $.each(arr, function(i, item){ 
  $.each(item,function(j,val){
     alert(j);
    alert(val);
 }); 
});

alert(j)은 0, 1, 2, 0, 1, 2, 0, 1, 2로 출력됩니다

alert(val)는 a, aa, aaa, b,로 출력됩니다. bb, bbb, c, cc, ccc

각각은 json 데이터를 처리합니다. 각각은 훨씬 더 강력하며 모든 속성을 순환할 수 있습니다

  var obj = { one:1, two:2, three:3}; 
  each(obj, function(key, val) { 
  alert(key); 
  alert(val); 
  });

여기에서 경고(키)는 하나 둘 셋

alert( val)을 출력합니다. 1, 1, 2, 2, 3, 3을 출력합니다

여기서 키가 숫자가 아닌 속성인 이유는 무엇입니까? json 형식은 순서가 지정되지 않은 속성 값의 집합이므로 숫자는 어디에 있습니까?
그리고 이 값은 obj[key]

ecah가 dom 요소를 처리하는 것과 동일합니다. 여기서는 입력 양식 요소가 예로 사용됩니다.

돔에 이와 같은 코드 조각이 있고


<input name="aaa" type="hidden" value="111" />
<input name="bbb" type="hidden" value="222" />
<input name="ccc" type="hidden" value="333" />
<input name="ddd" type="hidden" value="444"/>

각각을 다음과 같이 사용한다면

$.each($("input:hidden"), function(i,val){ 
alert(val);
alert(i);
alert(val.name);
alert(val.value); 
});

그런 다음, Alert(val)은 [object HTMLInputElement]를 출력합니다. 양식 요소.

alert(i)는 0, 1, 2, 3을 출력합니다

alert(val.name); aaa, bbb, ccc, ddd를 출력합니다. this.name을 사용하면 동일한 결과가 출력됩니다

alert( val.value); 111,222,333,444가 출력됩니다. this.value를 사용하면 동일한 결과가 출력됩니다. 위 코드를 다음 형식으로 변경하면 출력 결과가 동일함을 알 수 있습니다. .둘은 아직 글쓰기 방식의 차이를 잘 모르겠습니다. 이 변경 사항은 위의 배열 작업에 적용될 때 동일한 결과를 생성합니다.


이렇게 해서 여러 사례의 실제 결과가 답변되었습니다. 그런 다음 계속 공부하면 무슨 일이 일어나고 있는지, 왜 일어나는지 결코 알 수 없습니다.

위의 예에서 jQuery와 jQuery 개체 모두 이 메서드를 구현하는 것을 볼 수 있습니다. jQuery 개체의 경우에는 Each 메서드가 단순히 위임됩니다. jQuery 개체는 jQuery의 각 메서드에 첫 번째 매개 변수로 전달됩니다.


jQuery에서 각 구현을 살펴보세요

(인터넷 발췌)

$("input:hidden").each(function(i,val){
alert(i);
alert(val.name);
alert(val.value); 
});

jquery는 들어오는 요소를 기준으로 자동으로 판단한 다음 판단 결과에 따라 적용 또는 호출 방법을 사용합니다. fn 구현에서 이 포인터를 직접 사용하여 배열이나 객체의 하위 요소를 참조할 수 있습니다.

1.obj 객체는 배열입니다.

각 메서드는 특정 하위 요소를 호출하여 반환된 결과가 false가 될 때까지 배열의 하위 요소에 대해 fn 함수를 하나씩 호출합니다. 제공된 fn 함수를 사용하여 이를 처리하고 특정 조건을 충족한 후 각 메서드 호출을 종료할 수 있습니다. 각 메서드가 arg 매개변수를 제공하는 경우 fn 함수 호출에 의해 전달된 매개변수는 arg입니다. 그렇지 않으면 하위 요소 인덱스, 하위 요소 자체

2.obj 개체가 배열이 아닙니다

The 이 메소드와 1의 가장 큰 차이점은 fn 메소드가 반환 값에 관계없이 하나씩 실행된다는 것입니다. 즉, fn 함수가 false를 반환하더라도 obj 객체의 모든 속성은 fn 메서드에 의해 호출됩니다. 호출에 전달된 매개변수는 1과 유사합니다.

위 내용은 이 글의 전체 내용입니다. 모두 마음에 드셨으면 좋겠습니다.

위 내용은 jquery의 $each() 메소드 사용 안내의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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