规范中的JavaScript的内置属性和操作方法

前置

  • 引用是已解析的名称绑定。引用由三个组件组成,即基值、引用名称和布尔值严格引用标志。基值是未定义的、Object、Boolean、String、Number或环境记录。未定义的基值表示引用无法解析为绑定。引用的名称是一个字符串。
  • 本规范中使用了两种环境记录值:声明性环境记录和对象环境记录。声明性环境记录用于定义ECMAScript语言语法元素(如FunctionDeclarations、VariableDeclaration和Catch子句)的效果,这些语法元素直接将标识符绑定与ECMAScript语言值相关联。对象环境记录用于定义ECMAScript元素(如Program和WithStatement)的效果,这些元素将标识符绑定与某些对象的属性相关联。

一些对象的内部通用属性

  1. \[prototype\]\],可以通过Object.getPrototypeOf()方法拿到值

  2. \[call\]\],执行与对象关联的代码。通过函数调用表达式调用。

  3. \[ParameterMap\]\],提供arguments对象的属性和关联函数的形式参数之间的映射。只有作为参数对象的ECMAScript对象才具有。

  4. \[Get\]\],返回其值

  5. \[Delete\]\],从对象中删除指定的命名自身特性

getValue(v)

  1. 如果v不是一个引用则直接返回v本身
  2. let base = v的基值,如果基值是未定义的则抛出 ReferenceError 异常
  3. 如果基值是属性引用
    • 如果是对象,let get = 对象的[[GET]]方法
    • 如果不是对象,则让get为下方定义的get方法
  4. 否则v一定是环境变量的基本值
    • 返回环境记录中已存在的绑定的值。如果严格布尔值为true,并且绑定不存在或未初始化,则引发ReferenceError异常。
  • 当V是具有基元基值的属性引用时,GetValue将使用以下[[Get]]内部方法。它被称为使用基作为它的这个值,并使用属性P作为它的参数。采取以下步骤:
  1. let O = toObject(base)
  2. let desc = getProperty(O.p)
  3. if desc == undefined, return undefined
  4. 如果是value/writeable类型的,则返回desc.value
  5. 如果是setter/getter类型的
    • 如果getter不是函数,返回undefined
    • 如果返回getter的执行结果

putValue(v, w)

  1. 如果v不是引用,则抛出 ReferenceError 错误
  2. let base = v的基值
  3. 如果v是未定义的
    • 如果v的严格布尔值为true则抛出 ReferenceError 错误
    • 否则,将v作为全局对象的属性,并被赋值为w
  4. 如果v是属性引用
    • 是对象则调用内置的put方法,否则调用下面定义的put(同getValue操作,不过是赋值操作且异常是抛出TypeError)
  5. 到这里必然是环境变量的引用
    • 设置环境记录中已存在的可变绑定的值。name是绑定名称的文本。base是绑定的值,可以是任何ECMAScript语言类型的值。S是严格的模式引用布尔标志。如果S为true并且无法设置绑定,则引发TypeError异常

[[Delete]]操作

  1. let desc = 当前属性的描述符
  2. if desc == undefined, return true
  3. if desc.Configurable == true, remove property and return true
  4. 否则 严格模式下抛出 TypeError
  5. 返回 false
相关推荐
蚂蚁集团数据体验技术1 分钟前
一个可以补充 Mermaid 的可视化组件库 Infographic
前端·javascript·llm
LQW_home10 分钟前
前端展示 接受springboot Flux数据demo
前端·css·css3
q***d17316 分钟前
前端增强现实案例
前端·ar
IT_陈寒17 分钟前
Vite 3.0 重磅升级:5个你必须掌握的优化技巧和实战应用
前端·人工智能·后端
JarvanMo22 分钟前
Flutter 3.38 + Firebase:2025 年开发者必看的新变化
前端
Lethehong31 分钟前
简历优化大师:基于React与AI技术的智能简历优化系统开发实践
前端·人工智能·react.js·kimi k2·蓝耘元生代·蓝耘maas
华仔啊40 分钟前
还在用 WebSocket 做实时通信?SSE 可能更简单
前端·javascript
鹏北海1 小时前
多标签页登录状态同步:一个简单而有效的解决方案
前端·面试·架构
_AaronWong1 小时前
基于 Vue 3 的屏幕音频捕获实现:从原理到实践
前端·vue.js·音视频开发
孟祥_成都1 小时前
深入 Nestjs 底层概念(1):依赖注入和面向切面编程 AOP
前端·node.js·nestjs