美文网首页
JavaScript闭包

JavaScript闭包

作者: 大胃糕怕肥 | 来源:发表于2022-07-15 15:09 被阅读0次

JavaScript闭包是一种保护私有变量的机制,在函数执行时形成私有的作用域,保护里面的私有变量不受外界干扰。就是形成一个不销毁的栈环境。

如果你要设置一个计数器,代码如下:

var counter = 0;
 
function add() {
   return counter += 1;
}
 
add();
add();
add();
 
// 计数器现在为 3

但问题counter属于全局变量,页面上的其他脚本可以改变计数器。这样我们把它变成局部变量。

function add(){
    var counter = 1;
    return counter += 1;
}

add();
add();
add();

这里输出为1,并没有累计数字。

这里需要闭包,代码如下:

var add = (function () {
    var counter = 0;
    return function () {return counter += 1;}
})();

案例解析

这里的案例中变量 add 指定了函数自我调用的返回字值。

自我调用函数只执行一次。设置计数器为 0。并返回函数表达式。

add变量可以作为一个函数使用。它可以访问函数上一层作用域的计数器。

这个叫作 JavaScript 闭包。它使得函数拥有私有变量变成可能。

计数器受匿名函数的作用域保护,只能通过 add 方法修改。

注意事项

1、自调用函数外部的括号是必须的,如果没有加上JavaScript无法解析为一个函数表达式的自调用;而是解析为一个函数的声明和一个圆括号,并显示语法错误——圆括号内没有有效的表达式。

2、由于自调用函数是立即执行函数,其函数名称会自动被忽略,不能使用函数名调用,所以自调用函数没必要写函数名。

相关文章

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