闭包用于突破作用域function(){},指有权访问另一个函数作用中的变量的函数。
- 将函数中的变量可在函数外部访问
eg1:
function test1(){
var x=10;
return function(){
return x;
}
}
var a=test1();
console.log(a());//10
eg2:
var y;
function test2(){
var x=10;
y=function (){
return x;
}
}
test2();
console.log(y());//10
eg3:
function test3(e){
var y=function(){
return e;
}
e++;
return y;
}
var c=test3(123);
console.log(c());//124
- 闭包解决的函数内变量的输出问题
//直接输出变量只能获取最后变量状态
function test4(){
var x=[];
var i;
for(i=0;i<3;i++){
x[i]=function(){
return i;
}
}
return x;
}
var d=test4();
console.log(d[0]());//3
console.log(d[1]());//3
console.log(d[2]());//3
//使用自调用函数(IIFE)
function test4(){
var x=[];
var i;
for(i=0;i<3;i++){
x[i]=(function(a){
return function(){
return al
};
})(i)
}
return x;
}
var d=test4();
console.log(d[0]());//0
console.log(d[1]());//1
console.log(d[2]());//2
//使用子函数
function test5(){
function childxx(a){
return function(){
return a;
};
}
var x=[];
var i;
for(i=0;i<3;i++){
x[i]=childxx(i);
}
return x;
}
var d=test5();
console.log(d[0]());//0
console.log(d[1]());//1
console.log(d[2]());//2
注:let即可解决
- 闭包应用于内部变量的设置,使内部变量不暴露于外面
var getValue,setValue;
void function(){
var x=0;
getValue=function(){
return x;
};
setValue=function(a){
x=a;
};
}();
console.log(getValue());//0
setValue(10);
console.log(getValue());//10
4.迭代器
function dada(x){
var i=0;
return function(){
return x[i++];
}
}
var next=dada(['a','b','c']);
console.log(next());//a
console.log(next());//b
console.log(next());//c