一、闭包的概念
利用函数的嵌套,实现将第一层函数中的局部变量,可以在第一层函数外部修改的过程,叫闭包。
二、闭包的形成环境
1、函数的嵌套;
2、内部函数使用外部函数中的变量;
3、将内部函数返回,在外部函数的外部,接收返回值,执行(相当于执行了内部函数);
三、闭包的特点
1.解决掉所有的全局变量,节省内存空间;
2.可以在函数外部,修改函数内部的变量;
3.相对于局部变量来说,浪费了内存;
四、闭包的应用场景
1.循环中的事件,事件处理函数中使用了循环的每次的计数器
var ali = document.querySelectorAll(".list li");
for(var i=0;i<ali.length;i++){
// (function(index){
// ali[index].onclick = function(){
// console.log(index);
// }
// })(i);
ali[index].onclick = (function(index){
return function(){
console.log(index);
}
})(i);
}
2.给某些系统默认的回调函数,传参,比如(给计时器的回调函数,传参)
function fn(a){
return function(){
console.log(a);
};
}
setTimeout(fn("world"), 1000);
3.处理掉全局变量,只要开启新文件,新功能,最好上手就是一个匿名函数,简易闭包
var f = (function(){
var a = "hello";
function fn(){
console.log(a + "world");
}
return fn;
})();
f();
4、事件委托,利用到了闭包
obox.onclick = eveEnt(achild,function(){})
function eveEnt(eleArr,cb){
return function(eve){
eleArr
cb
}
}