>  기사  >  웹 프론트엔드  >  jquery의 각 메소드 사용 예 Sharing_jquery

jquery의 각 메소드 사용 예 Sharing_jquery

WBOY
WBOY원래의
2016-05-16 16:54:311052검색

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에서 사용되는 구현 방법입니다.

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