闭包
闭包 函数内部返回一个新的函数
1.函数作为另一个函数的返回值
var a = 200;
function fn1(){//0x0001
var a = 1;
return function (){//0x0002
console.log(a);//1
}
}
var fn = fn1(); //0x0002
fn();//–>1
2.函数作为参数被传递
function fnc1(fnc){
let a = 200;
fnc()
}
function fnc(){
console.log(a)
}
fnc1(fnc);
闭包的有优缺点
优点
(一)变量长期驻扎在内存中
(二)另一个就是可以重复使用变量,并且不会造成变量污染
缺点
由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。
作用域
1 全局 局部(函数) 块级
全局作用域
函数作用域 函数在执行的时候会产生一个独立作用域
块级作用域 ES新增的 ==>{}
作用域链
function内部存在预解释
自由变量: 当前作用域没有定义的变量
function的预解释优先级高于var出来的变量
自由变量的向上级作用域一层一层的查找,直到找到最高层全局作用域,这种机制 就是作用域链
var x = 30;
function test() { //x fn x
function x() {
}
alert(x); // fn x
var x = 10;
alert(x); //10
x = 20;
alert(x);//20 }
test();
作用域链==>自由变量的向上级作用域一层一层的查找,直到找到最高层全局作用域
自由变量==>a
var a = 10;
function x(){
console.log(a);
(function(){ console.log(a);//10
console.log(b);//undefined
})()
}
x()