美文网首页
JavaScript闭包

JavaScript闭包

作者: 流浪的三鮮餡 | 来源:发表于2019-04-29 15:57 被阅读0次

基本概念

JavaScript闭包就是指可以访问函数内部数据的函数。

解决问题

在函数内部定义的变量,在外部是无法访问的。可以使用闭包来获取函数内部的数据。

基本使用

常规:

function fun() {
      var num = Math.random();
      return num;
  } 

var a1 = fun();
var a2 = fun();
// 这样获取的函数内部数据 不是同一数据,所以值是不相同的。那么在实际开发时,不具有任何意义。

使用闭包:

function fun() {
      var num = Math.random();
      function fn() {
           return num;
        }
    return fn;
  }

var f = fun();
console.log( f() );
console.log( f() );
console.log( f() );

本质

闭包就是函数,而且要访问外层函数内部数据的内层函数。
只要外层函数执行一次,就会创建新的闭包。而闭包与闭包所缓存的数据,是在内存中不同的地址。因此是互不影响。

作用

可以存储数据。
一般情况,函数在执行完毕后,函数内部定义变量都会被垃圾回收机制的GC对象回收掉其所占用的内存。由于在函数外部,有其他变量对内部变量有所引用,所以导致函数内部的数据不能被GC回收掉,进而常驻内存。
因此,闭包的作用也是他的缺点。滥用闭包结构,会增大内存的开销,也有可能会造成内存泄露。
为了解决在使用闭包时,会造成内存泄露的问题,通常在使用完闭包后,将变量赋值为null。

获取函数内部多个数据

可以在外层函数中返回一个对象,存储多个闭包。

相关文章

  • 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/mimynqtx.html