JS에서 포토타입은 JS에서 이해하기 어려운 부분입니다. JavaScript 메소드는 클래스 메소드, 객체 메소드, 프로토타입 메소드의 세 가지 범주로 나눌 수 있습니다.
예:
function People(name) { this.name=name; //对象方法 this.Introduce=function(){ alert("My name is "+this.name); } } //类方法 People.Run=function(){ alert("I can run"); } //原型方法 People.prototype.IntroduceChinese=function(){ alert("我的名字是"+this.name); } //测试 var p1=new People("Windking"); p1.Introduce(); People.Run(); p1.IntroduceChinese();
obj1.func.call(obj) 메서드는 obj를 obj1로 처리하고 func 메서드를 호출하는 것을 의미합니다.
프로토타입은 무엇을 의미하나요?
Javascript의 모든 객체에는 프로토타입 속성이 있습니다. Javascript에서 객체의 프로토타입 속성에 대한 설명은 객체 유형의 프로토타입에 대한 참조를 반환한다는 것입니다.
?
A.prototype = new B();
프로토타입을 이해하는 것을 상속과 혼동해서는 안 됩니다. A의 프로토타입은 B의 인스턴스입니다. A가 B의 모든 메서드와 속성을 복제한 것으로 이해할 수 있습니다. A는 B의 메서드와 속성을 사용할 수 있습니다. 여기서 강조점은 상속보다는 복제에 있습니다. 이런 상황이 발생할 수 있습니다. A의 프로토타입은 B의 인스턴스이고 B의 프로토타입도 A의 인스턴스입니다.
먼저 실험적인 예를 살펴보겠습니다.
function baseClass() { this.showMsg = function() { alert("baseClass::showMsg"); } } function extendClass() { } extendClass.prototype = new baseClass(); instance = new extendClass(); instance.showMsg(); // 显示baseClass::showMsg
먼저 baseClass 클래스를 정의한 다음, extendClass를 정의하고 싶지만 baseClass의 인스턴스를 프로토타입으로 사용할 계획입니다. extendClass를 복제하려면 showMsg 객체 메소드도 포함되어 있습니다. extendClass.prototype = new baseClass()는 다음과 같이 읽을 수 있습니다. ExtensionClass는 baseClass의 인스턴스를 프로토타입으로 복제하여 생성됩니다.
그렇다면 'extendClass 자체에 baseClass의 메소드와 동일한 이름의 메소드가 포함되어 있으면 어떻게 될까요?'라는 질문이 생길 것입니다.
다음은 확장 실험 2입니다.
function baseClass() { this.showMsg = function() { alert("baseClass::showMsg"); } } function extendClass() { this.showMsg =function () { alert("extendClass::showMsg"); } } extendClass.prototype = new baseClass(); instance = new extendClass(); instance.showMsg();//显示extendClass::showMsg
실험은 함수가 실행될 때 먼저 온톨로지의 함수로 이동하여 이를 찾습니다. , 찾을 수 없으면 프로토타입 함수에서 검색됩니다. 또는 프로토타입이 동일한 이름을 가진 함수를 복제하지 않을 것이라고 이해할 수 있습니다.
그러면 새로운 질문이 생길 것입니다: baseClass의 객체 메소드 showMsg를 호출하기 위해 extendClass의 인스턴스를 사용하려면 어떻게 해야 할까요?
답은 다음과 같이 호출할 수 있다는 것입니다.
extendClass.prototype = new baseClass(); instance = new extendClass(); var baseinstance = new baseClass(); baseinstance.showMsg.call(instance);//显示baseClass::showMsg
baseinstance.showMsg.call(instance); 여기에서는 "인스턴스를 baseinstance로 호출하고 해당 개체 메서드 showMsg를 호출합니다"라고 읽습니다. 좋아, 여기서 baseClass.showMsg.call(instance);을 사용하면 안 되는지 묻는 사람이 있을 수 있습니다. 이것이 객체 메서드와 클래스 메서드의 차이점입니다. 우리가 호출하려는 것은 baseClass
의 객체 메서드입니다. 다음 코드를 명확하게 이해했다면 이 문서의 내용을 이해한 것입니다.
<script type="text/javascript"> function baseClass() { this.showMsg = function() { alert("baseClass::showMsg"); } this.baseShowMsg = function() { alert("baseClass::baseShowMsg"); } } baseClass.showMsg = function() { alert("baseClass::showMsg static"); } function extendClass() { this.showMsg =function () { alert("extendClass::showMsg"); } } extendClass.showMsg = function() { alert("extendClass::showMsg static") } extendClass.prototype = new baseClass(); instance = new extendClass(); instance.showMsg(); //显示extendClass::showMsg instance.baseShowMsg(); //显示baseClass::baseShowMsg instance.showMsg(); //显示extendClass::showMsg baseClass.showMsg.call(instance);//显示baseClass::showMsg static var baseinstance = new baseClass(); baseinstance.showMsg.call(instance);//显示baseClass::showMsg </script>