1、作用域
储存变量当中的值,并能在之后对这个值进行访问或者修改,正是这种储存和访问变量的值得能力将状态带给了程序
这些变量储存在那里?程序需要时如何找到?
设计良好的规则来存储变量,并且可以方便地找到这些变量。这套规则被成为作用域
1.1编译原理
js引擎可以根据需要创建并储存变量
1.2理解作用域
1.2.1 工作原理
- 引擎
负责整个js得编译及执行
- 编译器
引擎得好朋友,负责语法分析及代码生成等脏活累活
- 作用域
负责收集并维护由所有声明得标识符(变量)组成的一系列查询。并实施一套非常严格的规则,确定当前执行的代码对这些标识符的访问权限
1.2.2对话
var a = 2;
变量的赋值操作会执行两个动作,编译器会在当前作用域中声明一个变量(如果之前没有声明过),然后再运行时引擎会在作用域中查找该变量,如果能找到就给它赋值
1.2.3编译器
当变量出现再赋值操作的左侧时进行LHS查找,出现右侧则进行RHS查询 RHS理解为retrieve his source value(取到它的源值)
console.log(a); 对的a的引用是一个RHS引用,需要查找获取a的值,才能将值传递给console.log(..)
function foo(a) {
console.log(a);//2
}
foo(2);
//对foo进行rhs引用,找到foo的值,并把它给我,2分配给a,为了给a隐式的LHS
1.2.4 引擎和作用域的对话
function foo(a) {
console.log(a);//2
}
foo(2);
1.3作用域嵌套
作用域是根据名称查找变量的一套规则
1.4异常
ReferenceError 同作用域判别识别失败相关
TypeError 作用域判别成功,对结果的操作是非法或者不合理的