闭包

概念

一个函数对周围状态的引用捆绑在一起,内层函数中访问到其外层函数的作用域

简单理解:闭包 = 内层函数 + 外层函数的变量,内层函数使用外层函数的变量

function f1 () {
const num = 1
function f2 () {
console.log(num)
}
f2()
}
f1()

作用

  1. 封闭数据,提供操作,外部也可以访问函数内部的变量

    function f1 () {
    const num = 1
    function f2 () {
    console.log(num)
    }
    return f2
    }
    // 实现外部访问函数内部的变量
    const re = f1()
    re()
  2. 实现数据的私有

    比如,我们要做个统计函数调用次数,函数调用一次,就++

    // 实现数据的私有,函数外部只能调用,不能修改
    function countFun () {
    let count = 0
    function fn () {
    count++
    console.log(`调用了${count}次`);
    }
    return fn
    }
    const re = countFun()
    re()

    注意:根据标记清除法可知,闭包可能引起内存泄漏

posted @   丫丫learning  阅读(30)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 没有源码,如何修改代码逻辑?
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
点击右上角即可分享
微信分享提示