js 闭包

作者: 摸摸大海参 | 来源:发表于2019-12-27 14:53 被阅读0次

什么是闭包?
所谓闭包,就是可以访问函数内部变量的函数。

在JS中,函数内部是一个独立封闭的作用域,函数可以访问全局变量,但外部并不能访问函数内部的变量和方法。

var a = 1

function fn () {
  var b = 2
  console.log(a)
}

fn()   // 1
console.log(b)  // error, b is not defined

闭包主要有两个特性:
1、读取函数内部的变量;
2、被闭包引用的变量会一直存在内存中,函数调用后不会被清除。

function fn () {
    var a = 1;
    function getA () {
        return a++
    }
    
    return getA;
}

const sum = fn()
sum()   // 1
sum()   // 2
sum()   // 3

上面这个例子就可以说明闭包的特性了。a 被外部访问到,并一直存于内存中,由1到2再到3。

值得一提的是闭包可以解决一道经典面试题:

for (var i = 0; i < 3; i++) {
    setTimeout(() => console.log(i))
}
// 结果: 3 3 3

在执行 for 循环中,每一次都将一个 setTimeout 打入队列中。等到同步代码执行完毕,开始执行队列的setTimeout,因为 i 已经为3,所以结果就是打印3个3。

那用闭包怎么解决呢?在执行 for 循环中,每次创建一个作用域,将 i 保存在里面并被闭包使用:

for (var i = 0; i < 3; i++) {
    (function (j) {
      setTimeout(() => console.log(j))
    })(i)
}
// 结果: 0 1 2

相关文章

  • php之闭包函数(Closure)

    php闭包函数(Closure) JS闭包 js和php闭包使用和区别

  • JS闭包

    JS闭包 闭包练习

  • JS闭包问题(二)

    在之前的JS闭包问题(一)文章中大概介绍了一下JS闭包,同时讲了闭包与变量之间的问题,今天我们继续聊闭包,聊聊闭包...

  • JS闭包大结局(JS闭包系列3)

    在上一篇中再谈JS闭包(JS闭包系列2),我详细的介绍了JS中的变量作用域相关的概念,结合第一节关于JS闭包(JS...

  • JS闭包入门

    最近有看到朋友的面经里提到的JS闭包的问题,就想研究研究,以下是我对JS闭包的简单理解。 到底什么是JS闭包? 定...

  • 学习JavaScript闭包和作用域笔记

    JS JavaScript闭包和作用域 闭包 JavaScript高级程序设计中对闭包的定义:闭包是指有权访问另外...

  • 再谈JS闭包(JS闭包系列2)

    这篇文章,来继续谈谈Javascript闭包的剩余问题。因为在上一篇文章中关于JS闭包(JS闭包系列1)主要简单的...

  • 简单的聊一下闭包

    js中的闭包 闭包是学习js中永远也绕不过去的一个坎,那么,今天我们就去一段简单的代码开始聊一聊闭包 什么是闭包 ...

  • 浅谈闭包

    js中的闭包 闭包是学习js中永远也绕不过去的一个坎,那么,今天我们就去一段简单的代码开始聊一聊闭包 什么是闭包 ...

  • 闭包??

    什么闭包,闭包有什么用?http://js.jirengu.com/pogadikofa/1/闭包是在某个作用域内...

网友评论

      本文标题:js 闭包

      本文链接:https://www.haomeiwen.com/subject/wdddoctx.html