美文网首页Vue3
JavaScript 闭包

JavaScript 闭包

作者: 龚达耶 | 来源:发表于2020-01-07 17:04 被阅读0次

闭包 closure

引用了自由变量的函数(自由变量就是跨作用域的变量, 会一同存在即使离开也会)被外部访问

形成闭包条件(形成闭包的函数必须被外部变量引用(16),在函数中一定要访问外部函数的局部变量(10))

image.png

按理来说如果使用var let const在函数当中,此时就变为局部变量,只有在内部才能访问到。

并且当退出函数时就会随函数调用的结束而消失。

  var eat = function(){
    var food = 'cake'
    console.log(food)
  }
  eat(); // food
  console.log(food) // Uncaught ReferenceError: food is not defined

而我们闭包的函数在执行var look = eat()时反悔了匿名函数的引用,所以food就一直在环境中不会被销毁

所以我们在这里就可以引出闭包的第一个好处就是延续局部变量的生命周期

并且闭包可以帮我们把一些大函数的代码块独立出来。如果这些代码块不需要复用就可以用闭包封闭起来

相关文章

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