【JavaScript】27_函数闭包

15、函数

创建一个函数,第一次调用时打印1,第二次调用打印2,以此类推

可以利用函数,来隐藏不希望被外部访问到的变量

闭包:

闭包就是能访问到外部函数作用域中变量的函数

什么时候使用:

当我们需要隐藏一些不希望被别人访问的内容时就可以使用闭包

构成闭包的要件:

  1. 函数的嵌套

  2. 内部函数要引用外部函数中的变量

  3. 内部函数要作为返回值返回

    <script>
        // let num = 0
        // function fn(){
        //     num++
        //     console.log(num)
        // }

        // fn()

        function outer(){
            let num = 0 // 位于函数作用域中
            return () => {
                num++
                console.log(num)
            }
        }

        const newFn = outer()
        // console.log(newFn)
        newFn()
        newFn()
        newFn()
    </script>

函数在作用域,在函数创建时就已经确定的(词法作用域)

和调用的位置无关

闭包利用的就是词法作用域

    <script>
        let a = '全局变量a'

        function fn(){
            console.log(a)
        }

        function fn2(){
            let a = 'fn2中的a'
            fn()
        }

        fn2()//因为后来调用了方法fn(),该方法是定义在全局中的,所以调用的是'全局变量a'

        function fn3(){
            let a = 'fn3中的a'
            function fn4(){
                console.log(a)
            }
            return fn4;
        }

        let fn4 = fn3()
        fn4()
    </script>

16、闭包

闭包的生命周期:

  1. 闭包在外部函数调用时产生,外部函数每次调用都会产生一个全新的闭包

  2. 在内部函数丢失时销毁(内部函数被垃圾回收了,闭包才会消失)

注意事项:

闭包主要用来隐藏一些不希望被外部访问的内容,

这就意味着闭包需要占用一定的内存空间

注意事项:

相较于类来说,闭包比较浪费内存空间(类可以使用原型而闭包不能),

需要执行次数较少时,使用闭包

需要大量创建实例时,使用类

    <script>
        function outer(){
            let someVariable = 'someValue'

            return function(){
                console.log(someVariable)
            }
        }

        function outer2(){
            let num = 0;
            return () => {
                num++
                console.log(num)
            }
        }

        let fn1 = outer2()//独立闭包
        let fn2 = outer2()

        fn1()
        fn2()

        fn1 = null
        fn2 = null
    </script>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

名之以父

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值