作用域
全局执行上下文(全局作用域中)
1.在执行全局代码前将window确定为全局执行上下文
2.对全局数据进行预处理
- var定义的全局变量 赋值为underfined,添加为window的属性
- function函数声明的的方法,添加为window的方法
- this赋值为window
3.执行全局代码
函数执行上下文(局部作用域中)
1.调用函数,准备执行函数体前,创建对应的函数执行上下文
2.对局部数据进行预处理
- 形参变量赋值为实参,添加为执行上下文属性
- arguments赋值为实参列表,添加为执行上下文属性
- function声明的函数,添加为执行上下文的方法
- this赋值为 调用函数的对象
3.开始执行函数代码
块作用域
- try/catch 中的 cathc 子语句中声明的变量,是属于 catch 块的块级作用域。
- let/const let将变量声明依附在它所在的块儿(通常是{…})作用域中。const声明的常量
执行上下文栈(后进先出)
函数嵌套调用,当一个函数被调用时,该函数执行上下文就被压入一个环境栈中。而在函数执行之后,栈将该函数执行上下文弹出
变量提升与函数提升(优先变量提升)
- 变量在未定义时就可以访问到。(值为undefined)
- 函数在未定义时就可以执行
闭包
内部函数引入外部函数的变量;外部函数调用,内部函数执行定义时产生
常见方式
函数作为返回值
函数作为实参传入
作用:
延长变量的生命周期
封装函数中的变量,提高返回供外部访问,操作
缺点:可能造成内存泄漏(使用闭包后及时将变量赋为null)
生命周期:
内部函数执行定义时产生
内部函数成为垃圾对象时死亡
eg:
function fn(a){
return function(){
console.log(a);
};
}
var g=fn();//产生
g();
g=null;//死亡