jQuery의 각 함수는 매우 편리합니다. $.each() 함수는 1차원 배열, 다차원 배열, DOM, JSON 등을 탐색할 수 있는 매우 강력한 순회 함수를 캡슐화합니다. JavaScript 개발 프로세스 각각은 작업량을 크게 줄일 수 있습니다. 다음은 배열 유형 객체만 처리할 수 있는 각각을 모방하는 간단한 함수입니다.
$.each()는 $(selector).each()와 다릅니다. 후자는 jquery 객체를 탐색하는 데 특별히 사용됩니다(배열이든 객체이든). 배열입니다, 콜백 함수 배열의 인덱스와 해당 값이 전달될 때마다(값은 this 키워드를 통해서도 얻을 수 있지만 JavaScript는 항상 이 값을 객체로 래핑합니다. 문자열 또는 숫자), 메소드는 순회된 객체를 반환합니다. 의 첫 번째 매개변수
each() 메소드는 DOM 루프 구조를 간결하게 만들고 오류가 발생할 가능성을 줄입니다. Each() 함수는 매우 강력한 순회 함수를 캡슐화하고 사용하기가 매우 편리합니다. 1차원 배열, 다차원 배열, DOM, JSON 등을 순회할 수 있습니다. JavaScript 개발 프로세스 중에 $each를 사용하면 작업 부하를 크게 줄일 수 있습니다. .
다음은
각각의 1차원 배열 처리
var arr1 = [ "aaa", "bbb", "ccc" ]; $.each(arr1, function(i,val){ alert(i); alert(val); });
각 프로세스는
var arr2 = [['a', 'aa', 'aaa'], ['b', 'bb', 'bbb'], ['c', 'cc', 'ccc']] $.each(arr, function(i, item){ alert(i); alert(item); });
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(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); });
여기서 키가 숫자가 아닌 속성인 이유는 무엇입니까? 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(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 중국어 웹사이트의 기타 관련 기사를 참조하세요!