关于闭包的那些事

一、闭包的概念

利用函数的嵌套,实现将第一层函数中的局部变量,可以在第一层函数外部修改的过程,叫闭包。

二、闭包的形成环境

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
            }
        }
发布了17 篇原创文章 · 获赞 7 · 访问量 244

猜你喜欢

转载自blog.csdn.net/qq_44381873/article/details/104907023
今日推荐