>  기사  >  웹 프론트엔드  >  JS_javascript 기술의 프로토타입 이해

JS_javascript 기술의 프로토타입 이해

WBOY
WBOY원래의
2016-05-16 15:40:191208검색

모든 생성자에는 프로토타입이라는 속성이 있습니다. 이 속성은 특정 클래스에 대한 공통 변수나 함수를 선언하는 데 매우 유용합니다.

프로토타입의 정의

프로토타입 속성은 모든 생성자에 존재하므로 명시적으로 선언할 필요가 없습니다

이 글은 다음 지식을 바탕으로 작성되었습니다.

1개의 프로토타입 디자인 패턴

clone()을 사용하여 .Net에서 프로토타입 메서드를 구현할 수 있습니다

프로토타입 방식의 주요 아이디어는 이제 클래스 A가 있는데, 클래스 B를 만들고 싶다는 것입니다. 이 클래스는 A를 기반으로 하며 확장이 가능합니다. 우리는 B의 원형을 A라고 부릅니다.

2개의 JavaScript 메서드는 세 가지 범주로 나눌 수 있습니다.

수업 방법

b 객체 메소드

c 프로토타입 방법

예:

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(); 

3 obj1.func.call(obj) 메소드

obj를 obj1로 취급하고 func 메서드를 호출한다는 뜻입니다

자, 문제를 하나씩 해결해 보겠습니다.

프로토타입이 무슨 뜻인가요?

Javascript의 모든 객체에는 프로토타입 속성이 있습니다. Javascript에서 객체의 프로토타입 속성에 대한 설명은 객체 유형의 프로토타입에 대한 참조를 반환한다는 것입니다.

A.prototype = 새로운 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();
var instance = new extendClass();
instance.showMsg(); // 显示baseClass::showMsg

먼저 baseClass 클래스를 정의한 다음, ExtentClass를 정의하는데, 프로토타입으로 baseClass의 인스턴스를 사용할 계획이고, 복제할 ExtendedClass에도 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();
var instance = new extendClass();
instance.showMsg();//显示extendClass::showMsg

실험적 증명: 함수가 실행되면 먼저 온톨로지에서 함수를 찾고, 찾을 수 없으면 프로토타입에서 함수를 찾습니다. 또는 프로토타입이 동일한 이름을 가진 함수를 복제하지 않을 것이라고 이해할 수 있습니다.

그럼 새로운 질문이 생길 것입니다:
ExtensionClass의 인스턴스를 사용하여 baseClass의 객체 메소드 showMsg를 호출하려면 어떻게 해야 합니까?

전화를 사용하는 것이 정답입니다.

extendClass.prototype = new baseClass();
var 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();
var 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>

위 내용은 JS의 프로토타입에 대한 이해에 관한 내용입니다.

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