《JavaScript高级程序设计》读书笔记 之 执行环境及作用域

本文深入探讨了执行环境的概念,包括全局、函数和eval执行上下文,以及它们如何通过变量对象存储变量和函数。文章详细解释了作用域链的形成和工作原理,以及它是如何确保代码在不同环境中正确访问变量和函数的。

执行环境定义了变量和函数有权访问的其他数据,决定了它们各自的行为。

执行环境,或者叫执行上下文,每个执行环境都有一个与之关联的是 **变量对象。**存储了所有变量和函数。

分为:全局执行上下文、函数执行上下文、eval执行上下文。
在Web浏览器中,全局执行环境被认为是window对象。
每个函数都有自己的指定环境。当执行流进入一个函数,函数的环境会被推入一个环境栈(调用栈)

调用栈 中存放的就是执行上下文。

作用域:就是变量和函数的可访问范围。分为:全局作用域、函数作用域、块级作用域
当代码在一个环境中执行时,会创建变量对象的一个作用域链。作用域链的用途是,保证对执行环境有权访问的变量和函数可以有序访问。

代码描述

var color = 'blue';
function changeColor() {
  var anotherColor = 'red';
  
  function swapColor() {
    var tempColor = anotherColor;
    anotherColor = color;
    color = tempColor;
  }
  
  swapColor();
}
changeColor();

下图是changeColor函数作用域链和当前调用栈
image.png
下图是swapColor函数作用域链和当前调用栈
image.png

图例描述

执行环境.jpg
当某个函数第一次被调用时,会创建一个执行环境及相应的作用域链,并把作用域链赋值给一个特殊的内部属性[[Scope]]

var a = 2;
function add(b,c){
  return b+c;
}

function addAll(b,c){
	var d = 10;
  result = add(b,c)
  return a+result+d;
}
addAll(3,6);

调用栈.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

青菜小王子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值