前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >js闭包

js闭包

作者头像
陈灬大灬海
发布2018-09-12 15:43:13
3.8K0
发布2018-09-12 15:43:13
举报
文章被收录于专栏:面朝大海春暖花开

先展示两段代码块看看到底有什么区别

代码语言:javascript
复制
function foo(x) {
    var tmp = 3;
    return function (y) {
        alert(x + y + (++tmp));
    }
}
foo(2)(10);
代码语言:javascript
复制
function foo(x) {
    var tmp = 3;
    function bar(y) {
        alert(x + y + (++tmp));
    }
    bar(10);
}
foo(2)

这两段代码都是alert(16),区别到底在哪。

代码块①出现了闭包。

准确来说

 这块就是一个闭包。

闭包是基于正常的垃圾回收处理机制下的。也就是说,一般情况一个函数(函数作用域)执行完毕,

里面声明的变量会全部释放,被垃圾回收器回收。但闭包利用一个技巧,让作用域里面的变量,

在函数执行完之后依旧保存没有被垃圾回收处理掉。

或者说一下我现在的一个需求

我需要在for循环里面进行事件的绑定,这个应该怎么操作?

第一反应是这样(原生js)

代码语言:javascript
复制
<script>
window.onload=function(){
    var list = ['a','b'];
    for(var i in list){
        document.getElementById(list[i]).onclick=function(){
            alert(list[i]);
        }
    }
}
</script>
</head>
<body>
    <div id="a">aaa</div>
    <div id="b">bbb</div>
</body>

可以尝试一下,绝对都是alert(b)

原因就是执行完之后变量i被回收了。

可以换另一中方式

代码语言:javascript
复制
<script>
window.onload=function(){
    var list = ['a','b'];
    for(var i in list){
        (function(j){
            document.getElementById(list[j]).onclick=function(){
                alert(list[j]);
            }
        })(i)
    }
}
</script>
</head>
<body>
    <div id="a">aaa</div>
    <div id="b">bbb</div>
</body>

使用闭包来解决。nice!!!

我的low逼见解,前端了解就是。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档