>  기사  >  웹 프론트엔드  >  jquery_jquery의 $each() 메소드 사용 안내

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

WBOY
WBOY원래의
2016-05-16 16:01:411261검색

$.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를 출력합니다
경고(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차원 배열의 첫 번째 값을 취하는 것에 상대적입니다.
이 2차원 배열에는 3개의 배열 요소가 포함되어 있으므로 경고(i)는 0, 1, 2를 출력합니다.
경고(항목)은 ['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(key)는 하나 둘 셋을 출력합니다

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를 사용하면 동일한 결과가 출력됩니다

위 코드를 다음과 같은 형태로 변경하면

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

보시다시피 출력 결과는 동일합니다. 두 작성 방법의 차이점은 아직 모르겠습니다. 이 변경 사항은 위의 배열 작업에 적용될 때 동일한 결과를 생성합니다.

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

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

jQuery에서 각각의 구현을 살펴보세요(인터넷 발췌)

function (object, callback, args) {
//该方法有三个参数:进行操作的对象obj,进行操作的函数fn,函数的参数args
var name, i = 0,length = object.length;
if (args) {
if (length == undefined) {
for (name in object) {
if (callback.apply(object[name], args) === false) {
break;
}
}
} else {
for (; i < length;) {
if (callback.apply(object[i++], args) === false) {
break;
}
}
}
} else {
if (length == undefined) {
for (name in object) {
if (callback.call(object[name], name, object[name]) === false) {
break;
}
}
} else {
for (var value = object[0]; i < length && callback.call(value, i, value) !== false; value = object[++i]) {}
/*object[0]取得jQuery对象中的第一个DOM元素,通过for循环,
得到遍历整个jQuery对象中对应的每个DOM元素,通过 callback.call( value,i,value);
将callback的this对象指向value对象,并且传递两个参数,i表示索引值,value表示DOM元素;
其中callback是类似于 function(index, elem) { ... } 的方法。
所以就得到 $("...").each(function(index, elem){ ... });
*/
}
}
return object;
}

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

1.obj 객체는 배열입니다

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

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

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

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

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