作用域和作用域链[[scope]]

作用域
  • 前面的文章讲解了预编译的过程。就为作用域做了铺垫
  • js中的作用域 全局的GO, 函数的作用域AO。ES6 中的块级作用域。
  • 函数也是一中对象,引用类型。fun.name fun.length fun.prototype
  • 对象 -> 有些属性是我们无法访问的,JS引擎内部固有的隐式属性
  • [[scope]]:
  1. 函数创建时,生成的一个js内部隐式属性;
  2. 函数存储作用域链的容器。AO:函数执行期上下文;GO:全局执行期上下文。
  3. 函数执行完成后,AO是要销毁的。在次执行Fun时会重新生成AO
function a() {
    function b() {
        var b = 2;
    }
    var a = 1;
    b();
}
var c = 3
a();
/*
执行说明:
当a函数在定义时:
模块一:系统生成了[[scope]]属性,[[scope]]保存的是该函数的作用域链。
[[scope]] -> Scope Chain 作用域链

模块二: 该作用域链的第0位保存的是GO全局执行期上下文。
GO 里存储全局下的所有对象,其中包含函数a和全局变量c

Scope Chain 作用域链
0 -> GO 全局执行上下文

模块三:GO的内容:this     ->  window;
                  window   ->  object
                  document ->  object
                  a        ->  function
                  c        ->  3
*/
函数a“”
[[scope]]Scope Chain 作用域链

Scope Chain

Scope Chain作用域链“”
0GO

GO 全局执行上下文

GO全局执行上下文“”
thiswindow
windowobject
documentobject
afunction
c3
/*
当a函数被执行时(前一刻)
作用域链的顶端(第0位)存储a函数生成的函数执行期上下文AO,同时第一位存储的是GO
查找变量的顺序是从a函数的作用域链中从顶端开始一次向下查找
*/
函数a“”
[[scope]]Scope Chain 作用域链

Scope Chain

Scope Chain作用域链“”
0函数a的AO
1GO

a的AO

函数a的AO函数执行期上下文“”
thiswindow
arguments[]
a1
bfunction

GO 全局执行上下文

GO全局执行上下文“”
thiswindow
windowobject
documentobject
afunction
c3
/*
当b函数被定义时,
是在a函数环境下,所以b函数这时的作用域链就是a函数被执行期的作用域链。效果同上
*/
/*
当b函数被执行时(前一刻)
生成函数b的[[scope]],存储函数b的作用域链,顶端第0位存储b函数的AO,a函数的AO和全局的GO依次向下排列
*/
函数b“”
[[scope]]Scope Chain 作用域链

Scope Chain

Scope Chain作用域链“”
0函数b的AO
1函数a的AO
2GO

b的AO

函数b的AO函数执行期上下文“”
thiswindow
arguments[]
b2

a的AO

函数a的AO函数执行期上下文“”
thiswindow
arguments[]
a1
bfunction

GO 全局执行上下文

GO全局执行上下文“”
thiswindow
windowobject
documentobject
afunction
c3
/*
当b函数执行结束后,b函数的AO被销毁,回归被定义时的状态
*/
/*
当a函数被执行结束时,a函数的AO被销毁的同时,b函数的[[scope]]也将不存在。a函数回归到被定义时的状态。
*/
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
作用域是指在程序中定义变量的区域,它决定了变量的可见性和生命周期。作用域链是在函数执行时形成的,它是由当前函数的作用域和上层作用域的一系列变量对象组成的链式关系。作用域链的存在保证了在当前执行的作用域中可以有序地访问到符合访问权限的变量和函数。 作用域链的形成是在函数执行时发生的。当一个函数被调用时,会创建一个新的执行上下文,并将该执行上下文的作用域链初始化为当前函数的作用域。然后,它会将上一级函数的变量对象添加到作用域链中,形成一个链式关系。这样,当在当前函数中访问一个变量时,会先在当前函数的作用域中查找,如果找不到,就会继续在上一级函数的作用域中查找,直到找到或者到达全局作用域。 通过作用域链,函数可以访问到上层作用域中的变量和函数,但上层作用域不能访问到下层作用域中的变量和函数。这种嵌套的作用域作用域链的机制,使得程序可以灵活地组织和管理变量和函数,提高了代码的可读性和可维护性。 范例:<<引用:而作用域链,就是有当前作用域与上层作用域的一系列变量对象组成,它保证了当前执行的作用域对符合访问权限的变量和函数的有序访问。 。 引用:作用域链scopeChain的形成:作用域链是在函数执行的时候形成的。他包括当前函数的作用域[[scope]]、当前执行的上下文EC,以此来建立的一个链式关系 。 请回答我或者给我介绍或演示一下:什么是作用域作用域链? 作用域是指在程序中定义变量的区域,它决定了变量的可见性和生命周期。作用域链是在函数执行时形成的,它是由当前函数的作用域和上层作用域的一系列变量对象组成的链式关系。作用域链的存在保证了在当前执行的作用域中可以有序地访问到符合访问权限的变量和函数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值