我的编程空间,编程开发者的网络收藏夹
学习永远不晚

分享js闭包

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

分享js闭包

这篇文章主要讲解了“分享js闭包”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“分享js闭包”吧!

## 闭包

闭包是一个能读取其他函数内部变量的函数:

1. 闭包是一个函数

2. 这个函数能读取到其他函数内部的变量(局部变量)

3. 他能让读取到的变量始终保存在内存中

## 闭包的缺陷:

闭包函数读取到的变量会一直保存在内存中,不做处理地盲目使用很容易有内存泄漏(内存未释放或无法释放所造成的内存浪费,导致程序运行速度减慢)的风险

## 案例

说了一堆,来点干货

这个是从网上看到的一个案例

```

function fun(n,o){

  console.log(o);

  return {

    fun: function(m){

      return fun(m,n);

    }

  };

}

var a = fun(0);  // ?

a.fun(1);        // ?        

a.fun(2);        // ?

a.fun(3);        // ?

var b = fun(0).fun(1).fun(2).fun(3);  // ?

var c = fun(0).fun(1);  // ?

c.fun(2);        // ?

c.fun(3);

```

当时我把代码粘过来,边看程序边分析,把每一块分析的过程都写了下来

```

function fun(n, o) {

    console.log(o);

    return { // 这里返回一个对象,对象有个fun函数

        fun: function (m) { // 函数返回 调用fun 函数的返回值

            return fun(m, n);

        }

    };

}

var a = fun(0);  // ? 传参时只传了,所以n是,o为 undefined;a即为fun返回的对象

// a.fun() 就是闭包函数,var a = fun(0)中的 n=0,o=undefined 都会常驻在内存中

a.fun(1);        // ? 重新调用fun(n, 0),m = 1,n = 0,console.log(o),结果为

a.fun(2);        // ? 0

a.fun(3);        // ? 0

var b = fun(0).fun(1).fun(2).fun(3);  // ?  0 1 2

// 1. fun(0)为对象,此时的n = 0,o = undefined,输出 undefined

// 2. 然后调用对象的fun(m),m = 1,返回值为调用外部fun(n, o)的返回值,n = 1, o = 0 而这个返回值又是一个对象,输出

// 3. 然后又调用对象的fun(m),m = 2,返回值为调用外部fun(n, o)的返回值,n = 2, o = 1 而这个返回值又是一个对象,输出1

// 4. 然后又调用对象的fun(m),m = 3,返回值为调用外部fun(n, o)的返回值,n = 3, o = 2 而这个返回值又是一个对象,输出2

// 这里指的注意的是每次的n和o的值都不一样,是因为他们分别在不同的函数作用域内,这里每次都调用了一个新的fun(),开辟了一块新空间

var c = fun(0).fun(1);  // ? undefined,

// 而这里两次的结果都是1,因为他们都是通过c这个对象调用的,就是说因为他们都在同一个函数作用域内

c.fun(2);        // ?  1

c.fun(3);        // ?  1

```

分析的过程简直是一场头脑风暴,稍不留神就会跑偏,总算写完之后赶紧去对照他的答案(当时并没有跑一遍程序),结果发现`var b = fun(0).fun(1).fun(2).fun(3);`这里答案不一样,他给的答案是`undefined, 0, 0, 0`,而我得到的结果是`undefined, 0, 1, 2`,我就又回头看了一遍,觉得自己分析的没问题啊,这时候突然想到我还没跑一遍试试,于是抓紧跑一波,结果果然是站在我这边的。

感谢各位的阅读,以上就是“分享js闭包”的内容了,经过本文的学习后,相信大家对分享js闭包这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

分享js闭包

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

2024-04-02

JavaScript总结分享之闭包

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于闭包的相关问题,其中包括了闭包是什么、为什么要这么设计以及能怎么用的相关内容,下面一起来看一下,希望对大家有帮助。
2022-11-22

js中闭包的示例分析

这篇文章主要介绍了js中闭包的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1、说明闭包是具有很多变量和这些变量的环境的表现式(通常是函数),这些变量也是该表现式的一
2023-06-14

好程序员技术分享浅谈JavaScript中的闭包

好程序员技术分享浅谈JavaScript中的闭包,js闭包是指有权访问另一个函数作用域中的变量的函数,个人认为js闭包最大的用处就是防止对全局作用域的污染。 试想如果我们把一些仅仅只用到一两次的变量都声明在全局作用域中,最后肯定是容易出错且
2023-06-03

闭包在js中是什么意思

这篇文章跟大家分析一下“闭包在js中是什么意思”。内容详细易懂,对“闭包在js中是什么意思”感兴趣的朋友可以跟着小编的思路慢慢深入来阅读一下,希望阅读后能够对大家有所帮助。下面跟着小编一起深入学习“闭包在js中是什么意思”的知识吧。什么是闭
2023-06-29

带你走进JS中探索闭包

闭包是令人困惑的,因为它是一个“无形的”概念。当使用对象、变量或函数时,你会想:“在这里我需要一个变量”,然后将其添加到你的代码中。
JS闭包代码2024-12-11

go语言中闭包共享变量问题示例分析

这篇文章将为大家详细讲解有关go语言中闭包共享变量问题示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。直接看代码和注释:package mainimport ( "fmt" "time"
2023-06-14

web前端:js基础闭包练习题

编程学习网:在php、Scala、Scheme、CommonLisp、Smalltalk、Groovy、Javascript、Ruby、Python、Go、Lua、objectivec、Swift以及java(Java8及以上)等语言中都能找到对闭包不同程度的支持。
web前端:js基础闭包练习题
2024-04-23

编程热搜

目录