js闭包是什么?对js闭包的理解(附代码)

js中闭包closure,是指函数变量可以保存在函数作用域内,因此看起来是函数将变量“包裹”了起来,根据定义,包含变量的函数就是闭包。

js闭包是什么?对js闭包的理解(附代码)

本教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

最初的定义

闭包(closure),是指函数变量可以保存在函数作用域内,因此看起来是函数将变量“包裹”了起来。//根据定义,包含变量的函数就是闭包function foo() {    var a = 0;}cosole.log(a) // Uncaught ReferenceError: a is not defined

登录后复制

《JavaScript高级程序设计》对闭包定义

闭包是指有权访问另一个函数作用域中的变量的函数

 //根据《JavaScript高级程序设计》,访问上层函数的作用域的内层函数就是闭包function foo() {    var a = 2;    function bar() {        console.log(a);    }    bar();}foo();

登录后复制

《JavaScript权威指南》对闭包定义

函数对象可以通过作用域链相互关联起来,函数体内部变量可以保存在函数作用域内,这就是闭包。

 var global = "global scope"; //全局变量function checkscope() {    var scope = "local scope"; //局部变量    function f() {        return scope; //在作用域中返回这个值    };    return f();}checkscope(); // 返回 "local scope"

登录后复制

严格来说,闭包需要满足三个条件:

【1】访问所在作用域;

【2】函数嵌套;

【3】在所在作用域外被调用
有些人觉得只满足条件1就可以,所以IIFE是闭包;有些人觉得满足条件1和2才可以,所以被嵌套的函数才是闭包;有些人觉得3个条件都满足才可以,所以在作用域以外的地方被调用的函数才是闭包

为什么我们需要闭包,js闭包有什么用处

首先来看一个例子,我们来实现一个计数器。

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

登录后复制

现在我们已经达到了目的,可是问题来了,代码中的任何一个函数都可以随意改变counter的值,所以这个计数器并不完美。那我们把counter放在add函数里面不就好了么?

function add() {    var counter = 0;    return counter += 1;} add();add();add();// 本意是想输出 3, 但输出的都是 1

登录后复制

所以这样做的话,每次调用add函数,counter的值都要被初始化为0,还是达不到我们的目的。

如何使用闭包

所以这时候我们就要用闭包去解决这个问题了,先看代码。

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

登录后复制

这时候我们完美实现了计数器。这段非常精简,可以拆分成如下等价代码。

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

登录后复制

这时候的add就形成了一个闭包。一个闭包由两部分组成,函数和创建该函数的环境。环境是由环境中的局部变量组成的。对于闭包add来说,它由函数innerFunction和变量counter组成,所以这时候add是可以访问变量counter的。

使用闭包应注意的问题

由于闭包会携带包含它的函数的作用域,因此会比其他函数占用更多的内存。因此可以手动解除对匿名函数的引用,以便释放内存。

function f2(){    var n=22;    var nAdd=function(){n++};    return function(){        return {            n:n,            nAdd:nAdd        }    }}//result2就是创建了一个匿名函数var result2=f2();//调用函数console.log(result2());result2().nAdd();console.log(result2());//解除对匿名函数的引用,以便释放内存result2=null;

登录后复制

相关推荐:

JS闭包的使用

简单理解JS闭包

javascript深入理解js闭包

以上就是js闭包是什么?对js闭包的理解(附代码)的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2743881.html

(0)
上一篇 2025年3月8日 03:12:33
下一篇 2025年2月26日 06:31:24

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • js闭包有什么用处?js闭包的用法实例(附代码)

    本篇文章给大家带来的内容是关于js闭包有什么用处?js闭包的用法实例(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 js语言在函数内部可以直接读取全局变量,但函数外部无法读取函数内的局部变量 var n=100;…

    编程技术 2025年3月8日
    200
  • js闭包中this指向的解决方法(代码)

    本篇文章给大家带来的内容是关于js闭包中this指向的解决方法(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 下面是一个问题,对象方法中定义的子函数,子函数执行时this指向哪里?  三个问题:      (1)以…

    编程技术 2025年3月8日
    200
  • js中闭包性能优化的代码解析

    本篇文章给大家带来的内容是关于js中闭包性能优化的代码解析,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。     window.onload=function () {        var btn=document.ge…

    编程技术 2025年3月8日
    200
  • js闭包是什么?对js闭包的理解

    js中的闭包是什么?对于初次接触到闭包这个概念的朋友们,我相信很多的朋友都会有点不太理解,接下来的这篇文章将给大家来说一说js闭包该如何理解。 闭包(closure)是js中的一个难点,也是它的特色,很多高级应用都要依靠闭包来实现。所以我们…

    编程技术 2025年3月8日
    200
  • js闭包与作用域链是什么意思?js闭包与作用域链详解

    在学习js过程中会,必定要知道和明白的闭包。闭包是与其他编程语言相比,是js中所特有的一个。以下就是我对于闭包的认识。 闭包的产生:通俗的说,闭包产生于多个函数嵌套之间,当内层函数被保存到外面时,闭包就会产生。【推荐阅读:JavaScrip…

    2025年3月8日 编程技术
    200

发表回复

登录后才能评论