Mozilla 공식 웹사이트의 call() 소개는 다음과 같습니다.
Call() 매개변수
thisArg
Javascript의 call() 메소드
위의 복잡한 설명에 신경 쓰지 말고 단계별로 프로세스를 시작하세요.
Call() 메서드 인스턴스
그래서 또 다른 Hello, World를 썼습니다:
다음으로 또 다른 예를 살펴보겠습니다.
print.call(obj, "Hello", "World");
여기서만 전달하는 내용은 여전히 정의되지 않은 상태입니다. 이전 예에서 정의되지 않은 것은 매개변수를 전달해야 하기 때문입니다. 이것은 실제로 call의 사용법을 반영하지 않습니다. 더 나은 예를 살펴보겠습니다.
var h={p1:"hello", p2:"world", print:print};
h.print("fd");
var h2={p1:"hello", p2:"world"};
print.call(h2, "아무것도");
콜(Call)은 자신의 전화를 걸듯이 다른 사람의 방법과 객체를 빌려서 전화하는 것을 의미합니다. h.print에서 함수가 메소드로 호출되면 해당 객체를 가리킵니다. 단지 이 예에서는 h2가 print를 호출했는지, 아니면 h2를 호출했는지 이해하지 못했을 뿐입니다. 그래서 Mozilla의 사례를 인용했습니다
if (가격 < 0)
throw RangeError('음수 가격으로 "' 이름 '" 제품을 생성할 수 없습니다.');
이것을 돌려주세요;
}
기능식품(명칭, 가격) {
Product.call(이것, 이름, 가격);
This.category = '음식';
}
Food.prototype = 새 제품();
var Cheese = new Food('feta', 5);
console.log(치즈);
var h2= 함수(아니요){
This.p1 = "안녕하세요";
This.p2 = "세계";
Print.call(this, "아무것도");
};
h2();
여기서 h2는 print 함수를 호출하는 수신자 역할을 합니다. Food 예제에서와 같이 하위 생성자 내에서 상위 생성자의 호출 메서드를 호출하여 상속을 구현할 수 있습니다.
Call 메소드의 장점은 "Effective JavaScript"에서 소개합니다.
1. 호출 메서드를 사용하여 함수를 호출하도록 수신기를 맞춤설정합니다.
2. 주어진 객체에 존재하지 않는 메소드를 호출하려면 call 메소드를 사용하십시오.
3. call 메서드를 사용하여 사용자가 콜백 함수에 대한 수신자를 지정할 수 있도록 하는 고차 함수를 정의합니다.