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

JS闭包的知识点详解

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

JS闭包的知识点详解

本篇内容主要讲解“JS闭包的知识点详解”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JS闭包的知识点详解”吧!

一、什么是闭包?

学习一个陌生的概念,我们首先要去明白是什么?也就是闭包是什么?要想完全掌握闭包,一定要清楚函数作用域、内存回收机制、作用域继承。我们就简单讲一下这几个概念。

1. 函数作用域

作用域的概念,形象描述的话,可以认为它是一个封闭的空间,只允许在这个封闭的空间内进行一些操作,也将这个封闭空间称为私有作用域。在 JS  中,一个函数的执行就会在内存中创建一个私有作用域——封闭的空间。

JS闭包的知识点详解

JS闭包的知识点详解

比如在函数中定义一个变量,只能在函数这个私有作用域中使用(也就是封闭空间)。只要超出了这个作用域,就找不到该变量了。

而且函数执行完成后,这个私有作用域(封闭的空间)就会销毁。有一种情况它是不会销毁的,那就是“闭包”,后边会讲到。

2. 内存回收机制

内存回收机制就是不在用到的内存,我们系统就自动进行回收从而清理出空间供其他程序使用。那回收的规则是什么?

JS闭包的知识点详解

内部函数引用着外部的函数的变量,外部的函数尽管执行完毕,作用域也不会销毁。从而形成了一种不销毁的私有作用域。

某一变量或者对象被引用着,因此在回收的时候不会释放它,因为被引用代表着被使用,回收器不会对正在引用的变量或对象回收的。

3. 作用域继承

所谓的作用域继承,就像是儿子可以继承父亲的财产一样。比如小鹿这里有一个大的盒子作为一个父级的作用域,然后在这个大的盒子里边放一个小的盒子,作为子作用域。我们规定可以在小盒子中获取到大盒子中的东西,大盒子不能获取小盒子里的东西就称为作用域继承。

JS闭包的知识点详解

在 JS 中,道理是一样的,在一个函数里边我们再声明一个函数,内部函数可以访问外部函数作用域的变量,而外部的函数不能获取到内部函数的作用域变量。

那好,上边的这几个概念理解了之后,什么是闭包对你来说已经不是什么问题。

大白话说什么是闭包,那就是在一个函数里边再定义一个函数。这个内部函数一直保持有对外部函数中作用域的访问权限(小盒子一直可以有大盒子的访问权限)。

JS闭包的知识点详解

函数执行,形成一个私有的作用域,保护里边的私有变量不受外界的干扰,除了保护私有变量外,还可以存储一些内容,这样的模式叫做闭包。

动画实现:

JS闭包的知识点详解

二、闭包的作用是什么?

想必你对闭包还是有点懵懵懂懂,没关系,我们再继续深入了解。闭包主要的作用是什么呢?为什么要使用闭包呢?

通过上边对闭包的解释,外部函数 return  内部函数,但是仍然还是可以有访问外部函数的作用域,因为外部一直保持着引用。这就让我们发现它的可用之处。

不是有块作用域不销毁吗?我们可以用来保存一些内容,还可以用来保护一些私有的变量。我们总结出闭包有两个作用,分别为保护和保存。

三、闭包的应用场景

既然我们知道闭包的作用是保存和保护,那在实际项目中哪里用到了呢?

1. 保护作用

团队开发时,每个开发者把自己的代码放在一个私有的作用域中,防止相互之间的变量命名冲突;把需要提供给别人的方法,通过 return 或 window.xxx  的方式暴露在全局下。

jQuery 的源码中也是利用了这种保护机制。

2. 保存作用

选项卡闭包的解决方案。我们经常在网页中使用选项卡,但是它存在一个问题,那就是索引引发的问题,其实和下边的经典面试题问题相同。

四、经典的闭包面试题

循环绑定事件引发的索引什么问题?怎么解决这种问题?

JS闭包的知识点详解

此时运行程序,你会得出的结果都是 len 的数值。

为什么会出现这种问题,我们如何解决呢?

原因很简单,所有的事件绑定都是异步的,当触发点击事件,执行方法的时候,循环早就结束了。

我们在多说一点,什么是同步什么是异步?

  • 同步:JS 中当前这个任务没有完成,下面的任务都不会执行,只有等当前彻底完成,才会执行下面的任务。

  • 异步:JS 中的当前任务没有完成,需要等一会在完成,此时我们可以继续执行下面的任务。

解决方案:

当点击事件执行的时候,就会在私有作用域查找 i 的值,此时私有作用域没有 i ,就回去全局作用域查找,此时全局作用域的 i  已经被改变。所以说,要创建一个私有作用域的 i 。

方法一,闭包的方式。闭包终于排上用场了,用来保存私有的变量。

JS闭包的知识点详解

但是闭包解决又优点,也有缺点。优点就是通过创建私有作用域(闭包)方式解决,循环几次,就创建几个私有作用域(闭包),然后,每个私有作用域都有一个私有变量 i  ,存的值分别是循环的值。

缺点是生成多个不销毁的私有作用域(堆内存),对性能有一定的影响。

方法二,使用自定义属性。我们给每个对象添加一个索引属性就 OK 了。

JS闭包的知识点详解

终极解决方案,这是 ES6 中的知识,因为之前在 JS 中是没有块级作用域的概念的,到了 ES6 中就有了,Let  声明的变量就可以更好的解决上述问题。

JS闭包的知识点详解

到此,相信大家对“JS闭包的知识点详解”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

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

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

JS闭包的知识点详解

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

下载Word文档

猜你喜欢

RPM包知识点详细介绍

这篇文章主要介绍“RPM包知识点详细介绍”,在日常操作中,相信很多人在RPM包知识点详细介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”RPM包知识点详细介绍”的疑惑有所帮助!接下来,请跟着小编一起来学习吧
2023-06-16

Linux netfilter/iptables知识点详解

Netfilter Netfilter是Linux内核中的一个数据包处理模块,它可以提供数据包的过滤、转发、地址转换NAT功能。Iptables是一个工具,可以用来在Netfilter中增加、修改、删除数据包处理规则。 Netfilter是
2022-06-03

Java集合HashMap的知识点详解

这篇文章主要讲解了“Java集合HashMap的知识点详解”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java集合HashMap的知识点详解”吧!一、什么是哈希表在讨论哈希表之前,我们先大
2023-06-02

linux DMA接口知识点详解

1.两种DMA映射类型1.1. 一致性DMA映射(Consistent DMA mappings )主要用于映射长时间使用的区域。 CPU和DMA controller不需要考虑cache的影响。 这里的consistent实际上是cohe
2022-06-04

js如何使用闭包的注意点

这篇文章将为大家详细讲解有关js如何使用闭包的注意点,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1、使用注意(1)闭包会使函数中的变量全部部存储在内存中,内存消耗很大,所以不能滥用闭包,否则会导致网页性
2023-06-14

js知识点总结之getComputedStyle的用法

getComputedStyle是一个可以获取当前元素所有最终使用的CSS属性值,下面这篇文章主要给大家介绍了关于js知识点总结之getComputedStyle用法的相关资料,需要的朋友可以参考下
2022-11-13

详解Linux文件操作知识点

文件操作的相关系统调用 创建 int creat(const char *filename, mode_t mode);参数mode 指定新建文件的存取权限,它同umask 一起决定文件的最终权限(
2022-06-04

详解Java泛型(知识点总结)

概念来源:Java在设计开始之前不是通用的,直到它在JDK 1.5中被引入。Java泛型是通过擦除实现的。你知道什么是擦除吗?往下看。概念:常规类和方法只能使用特定类型;基本类型或自定义类。如果要编写可应用于多种类型代码的代码,这种严格的限制将对代码施加很大的
详解Java泛型(知识点总结)
2021-05-06

编程热搜

目录