美文网首页
JavaScript 闭包

JavaScript 闭包

作者: 鹤仔z | 来源:发表于2020-03-15 13:28 被阅读0次

本篇文章包懂

什么是闭包

总有人看到闭包就头疼,因为“闭包”二字实在让人搞不懂它的语义。但闭包其实是个很简单的概念:闭包就是一个函数,只不过这个函数有些不一样。至于它哪里不一样呢,可以用一句话总结出来闭包:

闭包就是一个可以访问另一个函数作用域中的变量的函数

因为我们在编程的过程中,有时候会有“想在一个函数内部也可以访问到另一个函数内部的变量”的需求,所以在这种情况下,闭包就应运而生了。

闭包的特性

  1. 函数嵌套函数
  2. 函数内部可以引用函数外部的参数和变量
  3. 参数和变量不会被垃圾回收机制回收

看不懂没关系,先观察以下的代码

一个简单的闭包

function fn1(){
    var a = 1;
    return function fn2(){ // fn2 就是一个闭包
        alert(a);
    }
}

var fn = fn1()

alert(a); // 报错:a is not defined
fn(); // 弹出 1

这段代码的逻辑很简单,甚至有人在不知道什么是闭包之前自己就用过闭包。

我们来剖析一下上边的代码:

  1. 定义一个函数fn1,在函数内定义一个变量 a=1
  2. 在函数fn1内返回一个 fn2
  3. 在 fn2 内 调用 fn1 的变量 a
  4. 定义一个 fn ,把 fn1 的返回值 —— fn2 赋值给 fn
  5. 此时 fn 就是 fn2 , 执行 fn ,成功弹出 1

通过观察代码我们知道, fn() 其实就是 alert(a) ,那为什么 fn() 可以成功访问到变量 a ,而直接 alert(a) 就不行呢?——当然不行,JavaScript 的变量引用是基于由下到上,由内而外的链式查找的,所以外部是不能访问到函数内定义的变量的。而闭包则替我们完成了这一点,因为闭包遵循链式查找的法则,而且基于它的特性:闭包访问到的参数和变量不会被垃圾回收机制回收,我们就成功的实现了在外部访问函数内部的变量

读到这里,你已经精通闭包了。

使用闭包的优越性

  1. 将函数内部变量进行封装,保证内部变量的私有化,外部无法直接访问。
  2. 避免了命名冲突。
  3. 将这个变量长期驻扎在内存之中,不会被销毁。(这一点要合理使用,如果过多的使用闭包会造成内存消耗过多)

稍后更新闭包的使用场景,等一个催更...

相关文章

  • JavaScript----闭包

    javascript之闭包 闭包的概念     闭包(closure)是 JavaScript 的一种语法特性。 ...

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

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

  • javascript中闭包是什么

    javascript中闭包是什么 JavaScript 变量可以是局部变量或全局变量。私有变量可以用到闭包。闭包就...

  • Javascript 闭包

    闭包 (注:所以案例以 javascript 实现) 初识闭包 什么是闭包 MDNClosures are fun...

  • 作用域闭包

    概览 背景知识:JavaScript内存管理、JavaScript作用域。 内容 1 闭包定义 闭包:当函数可以记...

  • JavaScript 作用域

    概览 背景知识:JavaScript内存管理、JavaScript作用域。 内容 1 闭包定义 闭包:当函数可以记...

  • 20170815 前端开发日报

    JavaScript闭包,只学这篇就够了 闭包不是魔法 这篇文章使用一些简单的代码例子来解释JavaScript闭...

  • JavaScript深入理解-闭包(Closure)

    推荐文章:学习Javascript闭包(Closure)- 阮一峰javascript深入理解-从作用域链理解闭包...

  • 闭包

    学习Javascript闭包(Closure)

  • JS之闭包与IIFE

    本篇文章主要讨论了: JavaScript引擎 全局对象 闭包 循环 + 闭包 IIFE + 闭包 1.JavaS...

网友评论

      本文标题:JavaScript 闭包

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