$.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(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]
와 동일합니다.
돔에 이런 코드가 있다면
<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를 사용하면 동일한 결과가 출력됩니다
$("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; }
1.obj 객체는 배열입니다
each 메소드는 특정 하위 요소를 호출하여 반환된 결과가 false가 될 때까지 배열의 하위 요소에 대해 fn 함수를 하나씩 호출합니다. 즉, 제공된 fn 함수를 사용하여 이를 처리할 수 있습니다. 특정 조건을 충족하도록 하세요. 각 메서드 호출을 종료하세요. 각 메소드가 arg 매개변수를 제공하는 경우 fn 함수 호출에 의해 전달된 매개변수는 arg입니다. 그렇지 않으면 하위 요소 인덱스, 하위 요소 자체
2.obj 개체가 배열이 아닙니다
이 메소드와 1의 가장 큰 차이점은 fn 메소드가 반환 값을 고려하지 않고 차례로 실행된다는 점입니다. 즉, fn 함수가 false를 반환하더라도 obj 객체의 모든 속성은 fn 메서드에 의해 호출됩니다. 호출에 전달된 매개변수는 1과 유사합니다.위 내용은 이 글의 전체 내용입니다. 모두 마음에 드셨으면 좋겠습니다.