ECMAScript 中的内部属性定义是为了什么

What Internal Property In ECMAScript is defined for?

本文关键字:什么 定义 属性 内部 ECMAScript      更新时间:2023-09-26

ECMAScript 中的内部属性是为什么定义的?规范是什么意思

此规范使用各种内部属性来定义 对象值的语义。这些内部属性不是 ECMAScript 语言。它们由此规范定义 纯粹出于说明目的。

这是否意味着 ECMAScript 定义的内部属性不可用于编程?它们用于javascript引擎的实现?

内部属性定义代码在执行时的行为,但无法通过代码访问。ECMAScript 为 JavaScript 中的对象定义了许多内部属性。内部属性由双方括号表示法表示。

例如,JavaScript 函数是一个对象,它具有 [[call]] 属性。[[调用]] 属性对于函数是唯一的。

另一个内部属性示例是 [[原型]] 属性。此属性是指向实例正在使用的原型对象的指针。由于无法通过代码访问内部属性,因此对象实例化无法访问原型,而其属性都可供对象使用。可以通过在对象上使用 Object.getPrototypeOf() 方法获取 [[prototype]] 属性的值。

var obj = new Object();
var prototype = Object.getPrototypeOf(obj);
console.log(prototype == Object.prototype);

这是否意味着 ECMAScript 定义的内部属性不可用于编程?它们用于javascript引擎的实现?

是的。它们仅用于实现目的,不需要"真实姓名"。您可以在 #8.6.2 对象内部属性和方法中阅读有关此内容的信息。

常用的例子是内部属性 [[prototype]],所有对象都有一个,但你不能直接访问它,例如。

function foo(){
    this.first = "hi"
    this.second = something
}
foo.prototype = {
    constructor : foo,
    anotherProp : "hello"
}
var obj = new foo();
console.log(obj.anotherProp); //hello
//here the runtime will look in obj for anotherProp and
//fail to find it so it will look in obj's internal property
//[[prototype]] which is pointing to the object foo.prototype

因此,您可以访问内部属性 [[prototype]] 指向的对象,但不能直接通过内部 [[prototype]] 属性访问,该属性仅供运行时使用,而不是供程序员使用。

它们用于如何实现 JavaScript 引擎的示例