深入理解JavaScript之执行上下文和变量对象

本文深入探讨JavaScript的执行上下文,重点讲解变量对象(VO)的概念、创建过程,包括形参赋值、函数声明和变量声明,并讨论全局上下文与函数上下文下的变量对象差异,以及变量对象转变为活动对象的过程。
摘要由CSDN通过智能技术生成

继续接着上篇文章,上篇我们说到函数上下文的结构可表示为

const ExecutionContextObj = {
   
    VO: window,     // 变量对象
    ScopeChain: {
   }, // 作用域链
    this: window
};

即每个函数上下文,都要有这三个重要属性:

  • 变量对象(Variable object, VO)
  • 作用域链(Scope chain)
  • this

今天再细说执行上下文中的变量对象

变量对象

1.什么是变量对象

变量对象是与执行上下文的相关的数据作用域,存储了在上下文中定义的变量和函数声明。因为不同执行上下文的变量对象略有不同,所以变量对象一般分为全局上下文下的变量对象和函数上下文下的变量对象。

2.变量对象(VO)的创建过程

变量对象的创建,属于执行上下文中的创建阶段,依次经过以下三个过程:

创建执行上下文有两个阶段:一个是创建阶段,一个是执行阶段。变量对象的创建,属于执行上下文中的创建阶段,会依次经过三个过程:

1.为函数的形参赋值(函数上下文)

在进入函数执行上下文时,会首先检查实参个数,接着对实参对象和形参进行赋值。如果没有实参,属性值设为undefined;当传入的实参数量小于形参数量,则会将没有被赋值的形参赋值为 undefined。

function fn(a, b, c){
   
    console.log(a, b, c); // 1 2 undefined
}
fn(1, 2);

此时变量对象的结构为:

VO = {
   
    a: 1,
    b: 2,
    c
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值