我知道每个 JavaScript 对象都有一个名为[[Prototype]]
. 某些实现允许通过调用的属性访问它,__proto__
而其他实现则不允许。这个属性周围的括号有什么特殊意义吗?
JavaScript 中 [[prototype]] 属性的双括号有什么意义?
它是对象的“内部属性”。从ECMAScript 8.6.2 开始:
本规范使用各种内部属性来定义对象值的语义。这些内部属性不是 ECMAScript 语言的一部分。本规范定义它们纯粹是为了说明目的。ECMAScript 的实现必须表现得好像它以此处描述的方式生成和操作内部属性。内部属性的名称括在双方括号 [[ ]] 中。
“这些内部属性不是 ECMAScript 语言的一部分”这句话意味着内部属性不是可以在实际代码中使用的标识符——内部属性不能作为包含它们的对象的成员访问。然而,它们可以被制成通过特定功能或特性(例如,一些浏览器的一种足以让你设置和获取访问[[Prototype]]
通过__proto__
属性和ES5规范允许只读通过查阅Object.getPrototypeOf
)。
在单括号上使用双括号可能是为了避免与实际括号表示法(即属性访问)发生任何可能的混淆。
JavaScript [[原型]]
双括号[[Prototype]]
是将一个对象与另一个对象联系起来的内部链接。
创建函数时,会创建一个名为原型的属性对象,并将其添加到函数的名称变量(我们称之为constructor
)。此对象指向或具有指向本机 JavaScript 对象的内部私有链接)。
例子:
function Foo () {
this.name = 'John Doe';
}
// Foo has an object 'property' called prototype
// prototype was created automatically when we declared the function Foo.
// Now, we can assign properties to it without declaring the prototype object first.
Foo.prototype.myName = function () {
return 'My name is ' + this.name;
}
现在,如果我们要Foo
使用new
关键字创建一个新对象,我们基本上会创建(除其他外)一个新对象,该对象具有指向Foo
我们之前讨论过的函数原型 ( )的内部链接:
var obj = new Foo();
obj.__proto__ === Foo.prototype // true
obj.[[Prototype]] === Foo.prototype // true
作为
obj.__proto__ === obj.[[Prototype]] // true
由于[[Prototype]]
是该函数对象的私有链接,因此许多浏览器都为我们提供了公共链接。那就是__proto__
(读作 dunder proto)。
__proto__
实际上是一个属于本机 JavaScript 对象的getter函数,并返回任何this
绑定的内部私有原型链接(返回[[Prototype]]
of obj
):
obj.__proto__ === Foo.prototype // true
顺便说一句,从 开始ES5
,我们可以使用该getPrototypeOf
方法来获取内部私有链接:
obj.__proto__ === Object.getPrototypeOf(obj) // true
注意:这个答案并不打算涵盖创建新对象或新构造函数的整个过程,而是为了帮助更好地理解什么是什么[[Prototype]]
以及它是 如何工作的。
它在括号中的原因是表示它是私有财产。括号本身从未在任何地方的代码中使用。
正如您所指出的,某些实现提供对 下的私有属性的访问__proto__
,但它是非标准的。