>웹 프론트엔드 >JS 튜토리얼 >JS 프로토타입에 대한 자세한 설명

JS 프로토타입에 대한 자세한 설명

不言
不言원래의
2018-07-14 17:48:201641검색

이 글은 주로 참고할 가치가 있는 JS 프로토타입의 자세한 설명을 소개합니다. 이제 모든 사람들과 공유합니다. 도움이 필요한 친구들이 참고할 수 있습니다

JS에서 포토타입은 JS에서 이해하기 어려운 부분입니다

이것은 기사는 다음 지식 포인트를 기반으로 합니다.

1 프로토타입 디자인 패턴

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

프로토타입 메서드의 주요 아이디어는 이제 1개가 있다는 것입니다. A 클래스, A 클래스를 프로토타입화하고 확장할 수 있는 B 클래스를 만들고 싶습니다. 우리는 B의 원형을 A라고 부릅니다.

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

a 클래스 메서드

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

먼저 baseClass 클래스를 정의한 다음 ExtentClass를 정의합니다. 하지만 프로토타입으로 baseClass의 인스턴스를 사용할 계획이고 복제할 확장 클래스에도 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

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

그러면 새로운 질문이 생길 것입니다:

extendClass의 인스턴스를 사용하여 baseClass의 showMsg 객체 메소드를 호출하려면 어떻게 해야 할까요?

call:

extendClass.prototype = new baseClass();
var instance = new extendClass();


var baseinstance = new baseClass();
baseinstance.showMsg.call(instance);//显示baseClass::showMsg

baseinstance.showMsg.call(instance);을 사용할 수 있다는 것입니다. 여기에서는 "인스턴스를 baseinstance로 호출하고 해당 개체 메서드 showMsg를 호출합니다"라고 읽습니다.

좋아, 누군가가 여기에서 질문할 수도 있습니다. use 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>

위 내용은 이 글의 전체 내용입니다. 더 많은 관련 내용을 보려면 PHP 중국어 웹사이트를 주목하세요.

관련 권장사항:

js의 함수 선언 및 함수 표현식 분석

js를 통해 의사 배열을 배열로 변환하는 방법

위 내용은 JS 프로토타입에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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