JavaScript学习-执行环境和作用域

1,执行环境

执行环境,有时也称为“环境”,执行环境定义了变量和函数有权访问的其他数据,决定了它们各自的行为。每个执行环境都有一个与之关联的变量对象,环境中定义的所有变量和函数都保存在这个对象中,我们编写的代码无法访问这个对象,但解析器在处理数据时会在后台使用它。

  • 全局执行环境是最外围的一个执行环境。
  • 每个函数都有自己的执行环境。
  • 执行环境的类型总共只有两种—全局和局部(函数)

2,作用域链

当代码在一个环境中执行时,会创建变量对象的一个作用域链。作用域链的用途,是保证对执行环境有权访问的所有变量和函数的有序访问。

  • 作用域链的前端,始终都是当前执行的代码所在换将的变量对象。
  • 如果执行环境是函数,则将其活动对象作为变量对象。
  • 作用域链中的下一个变量对象来自包含(外部)环境,以此类推,再下一个变量对象则来自下一个包含对象。
  • 全局执行环境的变量对象始终都是作用域链中的最后一个对象。

3,延长作用域链

有些语句可以在作用域链的前端添加一个变量对象,该变量对象会在代码执行后被移出。就是当执行流进入下列任何一个语句时,作用域链就会得到加长:

  • try-catch语句的catch块;
  • with语句。

4,没有块级作用域

对于JavaScript来说,由if或for语句中的变量声明会将变量添加到当前的执行环境,在语句结束后,也依旧会存在于语句外部的执行环境中。 代码示例:

  • if语句
if(true){
    var color = “blue”;
}
alert(color); // blue
  • for语句
for(var i = 0; i  < 10;i++)\{
    doSomething(i);
}
alert(i); //10

5,查询标识符

标识符解析是沿者作用域链一级一级的搜索标识符的过程。搜索过程始终从作用域链的前端开始,然后逐级向后回溯,直到找到标识符为止,如果找不到标识符,则意味着该变量尚未声明。在严格模式下,初始化未经声明的变量会导致错误。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值