>웹 프론트엔드 >JS 튜토리얼 >js 프로토타입 체인 원리 다이어그램 설명_자바스크립트 기술

js 프로토타입 체인 원리 다이어그램 설명_자바스크립트 기술

WBOY
WBOY원래의
2016-05-16 17:51:591274검색

ECMAscript의 창시자는 상속된 속성을 유지하면서 언어를 단순화하기 위해 이 연결 목록을 설계했습니다. .
데이터 구조의 연결 목록에 대해 배운 적이 있나요? 연결 목록에는 다음 구조를 가리키는 포인터와 동일한 위치가 있습니다.

따라서 __proto__도 마찬가지입니다. 프로토타입을 정의할 때마다 인스턴스의 __proto__를 구조체에 가리키는 것과 동일합니다.

글이 좀 복잡합니다. 그림을 보고 말해보세요

코드를 복사하세요 코드는 다음과 같습니다. 다음:

var foo = {
x: 10,
y: 20
}

Figure 1. A basic object with a prototype.


__proto__를 지정하지 않으면 foo도 해당 속성을 예약합니다.

클리어 포인터가 있으면 연결된 목록이 연결됩니다.

분명히 아래 그림의 b와 c는 a의 속성과 메소드를 공유함과 동시에 각자의 private 속성을 가지고 있습니다.

__proto__에도 기본적으로 포인팅 기능이 있습니다. 이는 최고 수준의 object.prototype을 가리키며, object.prototype의 __proto__는 비어 있습니다.
코드 복사 코드는 다음과 같습니다.

var a = {
x: 10,
계산: function (z) {
return this.x this.y z
}
}
var b = {
y: 20,
__proto__: a
};

var c = {
y: 30,
__proto__: a
}// 상속된 메서드 호출
b .calculate( 30); // 60



Figure 2. A prototype chain.속성 링크 포인터 __proto__의 성격을 이해하세요. . 생성자를 다시 이해해 봅시다.


프로토타입이 정의되면 프로토타입 객체가 생성되며, 이 프로토타입 객체는 프로토타입을 생성하는 함수의 프로토타입 메소드에 저장됩니다. 🎜> 코드 복사


코드는 다음과 같습니다.
function Foo(y){ this.y = y } Foo.prototype.x = 10;
Foo.prototype.calculate = function(z){
return this.x this.y z; >var b = new Foo(20);

alert(b.calculate(30))





[참고문서]


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