浅理解:
函数执行时会先创建当前的上下文环境,其中这两点会产生“变量提升”的效果
- 变量定义
- 函数声明
深入理解:
在一段 JS 脚本(即一个标签中)执行之前,会先创建一个全局执行上下文环境,先把代码中即将执行的(内部函数的不算,因为你不知道函数何时执行)变量、函数声明(和“函数表达式”的区别)都拿出来。变量先暂时赋值为undefined,函数则先声明好可使用。这一步做完了,然后再开始正式执行程序。再次强调,这是在代码执行之前才开始的工作。
另外,一个函数在执行之前,也会创建一个函数执行上下文环境,跟全局上下文差不多,不过函数执行上线文中会多出this arguments和函数的参数。
总结:
- 范围:一段
<script>
代码或者一个函数 - 全局:变量定义,函数声明
- 函数:变量定义,函数声明,this,arguments,参数
例子:
console.log(a) // undefined
var a = 100
fn('zhangsan') // 'zhangsan' 20
function fn(name) {
age = 20
console.log(name, age)
var age
}