jQuery 객체의 경우 각 메소드는 단순히 위임됩니다. 즉, jQuery 객체는 jQuery의 각 메소드에 첫 번째 매개변수로 전달됩니다. 즉, jQuery에서 제공하는 각 메소드는 매개변수 1에서 제공하는 객체에 대한 것입니다. 메서드의 모든 하위 요소는 하나씩 호출됩니다. jQuery 객체가 제공하는 각 메소드는 jQuery 내부의 하위 요소를 하나씩 호출합니다.
jQuery.prototype.each=function( fn , args ) {
return jQuery.each( this, fn, args )
jQuery에서 제공하는 각 메소드의 구체적인 구현을 살펴보겠습니다. jQuery.each(obj,fn,arg)
이 메서드에는 세 가지 매개변수가 있습니다: 연산할 객체 obj, 연산할 함수 fn, 함수 매개변수 args.
ojb 개체 측면에서 논의해 보겠습니다.
1. obj 객체는 배열입니다
each 메소드는 특정 하위 요소를 호출하여 반환된 결과가 false가 될 때까지 배열의 하위 요소에 대해 fn 함수를 하나씩 호출합니다. 즉, 제공된 fn 함수를 사용하여 이를 처리할 수 있습니다. 특정 조건을 충족하도록 하세요. 각 메서드 호출을 종료하세요. 각 메소드가 arg 매개변수를 제공하는 경우 fn 함수 호출에 의해 전달된 매개변수는 arg입니다. 그렇지 않으면 하위 요소 인덱스, 하위 요소 자체입니다.
2. obj 객체가 배열이 아닙니다
이 메소드와 1의 가장 큰 차이점은 fn 메소드가 반환 값을 고려하지 않고 차례로 실행된다는 점입니다. 즉, fn 함수가 false를 반환하더라도 obj 객체의 모든 속성은 fn 메서드에 의해 호출됩니다. 호출에 전달된 매개변수는 1과 유사합니다.
jQuery.each=function( obj, fn , args ) {
if ( args ) {
if ( obj.length == 정의되지 않음 ){
for ( var i in obj )
fn.apply( obj, args )
}else{
for ( var i = 0, ol = obj.length; i < ol; i ) {
if ( fn.apply( obj, args ) === false )
break;
}
}
} else {
if ( obj.length == undefine ) {
for ( var i in obj )
fn.call( obj, i, obj ) ;
} Else {
for (var I = 0, OL = OBJ.Length, VAL = OBJ [0]; I & LT; OL && FN.CALL (VAL, I, Val)! == False ; Val = Obj [ i] ){}
}
}
obj 반환
}
각 메소드에서 fn의 구체적인 호출 메소드는 단순한 fn(i, val) 또는 fn(args)가 아니라 fn.call(val,i,val) 또는 fn의 형식이라는 점에 유의하는 것이 중요합니다. apply(obj.args)는 fn의 자체 구현에서 이 포인터를 직접 사용하여 배열이나 객체의 하위 요소를 참조할 수 있음을 의미합니다. 이 방법은 대부분의 jQuery에서 사용되는 구현 방법입니다.