【JS基础】闭包

在阅读vue源码时发现vue源码大量运用了闭包的技巧来实现某些特性,发现自己并不是真的理解闭包,所以写这篇文章来深入学习闭包

闭包的概念

闭包是 JS 的常见概念,它是一个函数嵌套了内部函数,并返回这个内部函数的形式,返回的内部函数引用了外层函数的变量,就会以闭包的形式保存下来。

MDN上的解释:闭包 (closure)是一个函数以及其捆绑的周边环境状态(lexical environment词法环境)的引用的组合。

可能我们在书写js代码时,不知不觉中已经使用了闭包。我们从下边这段代码具体来看一下:

javascript 复制代码
function foo() {
  var a = 2;

  function bar() {
    console.log(a);
  }

  return bar;
}

var baz = foo();
baz(); // 2------朋友,这就是闭包的效果。

这段代码中,函数foo(),内部有一个局部变量a以及一个函数bar(),并且返回了函数bar。 在foo执行后,通常会觉得foo内部的作用域已经销毁,它内部的a变量应该不复存在。但由于闭包的性质,函数bar()内部引用foo的内部作用域,而这个引用就叫做闭包。

闭包的用处

闭包给JavaScript代码带来了很多的灵活性,它的最大用处有两个,一个是前面提到的可以读取函数内部的变量,另一个就是让这些变量的值始终保持在内存中。 来看下边这段代码:

javascript 复制代码
// 函数add返回了一个内部函数,这个内部函数持有add的参数的引用。
function add(a){
	return (b)=> b+a
}
const add5 = add(5) // add5通过闭包的性质可以引用add的局部变量a。
add5(1) //6

理解闭包

要理解闭包,需要理解作用域链。还是以上文中的代码为例: 内部函数的作用域链中持有add函数的活动对象,所以在add函数执行完返回内部函数后,add函数的活动对象a仍然不会被销毁,直到持有内部函数的引用的对象全部被销毁后。

使用闭包的注意点

由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。

相关推荐
不一样的少年_2 分钟前
产品催: 1 天优化 Vue 官网 SEO?我用这个插件半天搞定(不重构 Nuxt)
前端·javascript·vue.js
-dcr3 分钟前
50.智能体
前端·javascript·人工智能·ai·easyui
行者9613 分钟前
Flutter跨平台开发适配OpenHarmony:进度条组件的深度实践
开发语言·前端·flutter·harmonyos·鸿蒙
云和数据.ChenGuang14 分钟前
Uvicorn 是 **Python 生态中用于运行异步 Web 应用的 ASGI 服务器**
服务器·前端·人工智能·python·机器学习
IT_陈寒16 分钟前
SpringBoot 3.0实战:这5个新特性让你的开发效率提升50%
前端·人工智能·后端
遗憾随她而去.24 分钟前
Webpack 面试题
前端·webpack·node.js
我要敲一万行25 分钟前
前端文件上传
前端·javascript
恋猫de小郭27 分钟前
Tailwind 因为 AI 的裁员“闹剧”结束,而 AI 对开源项目的影响才刚刚开始
前端·flutter·ai编程
要加油哦~28 分钟前
算法 | 整理数据结构 | 算法题中,JS 容器的选择
前端·javascript·算法
一只小bit28 分钟前
Qt 重要控件:多元素控件、容器类控件及布局管理器
前端·c++·qt