好程序员web前端教程分享js闭包

简介: 好程序员web前端教程分享js闭包为了更好的理解闭包,从网上搜罗了很多资料,集各家之精华(自认为),拼拼凑凑自己总结了一下。闭包闭包是一个能读取其他函数内部变量的函数:闭包是一个函数这个函数能读取到其他函数内部的变量(局部变量)他能让读取到的变量始终保存在内存中闭包的缺陷:闭包函...

好程序员web前端教程分享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);  // ? 传参时只传了0,所以n是0,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),结果为0
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 而这个返回值又是一个对象,输出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,0
// 而这里两次的结果都是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,我就又回头看了一遍,觉得自己分析的没问题啊,这时候突然想到我还没跑一遍试试,于是抓紧跑一波,结果果然是站在我这边的。

相关文章
|
6月前
|
前端开发 JavaScript 开发者
JavaScript:无处不在的Web语言
JavaScript:无处不在的Web语言
|
6月前
|
前端开发 JavaScript 开发者
JavaScript:构建动态Web的核心力量
JavaScript:构建动态Web的核心力量
|
7月前
|
JavaScript 前端开发 Java
前端框架选择之争:jQuery与Vue在现代Web开发中的真实地位-优雅草卓伊凡
前端框架选择之争:jQuery与Vue在现代Web开发中的真实地位-优雅草卓伊凡
700 72
前端框架选择之争:jQuery与Vue在现代Web开发中的真实地位-优雅草卓伊凡
|
10月前
|
前端开发 算法 API
构建高性能图像处理Web应用:Next.js与TailwindCSS实践
本文分享了构建在线图像黑白转换工具的技术实践,涵盖技术栈选择、架构设计与性能优化。项目采用Next.js提供优秀的SSR性能和SEO支持,TailwindCSS加速UI开发,WebAssembly实现高性能图像处理算法。通过渐进式处理、WebWorker隔离及内存管理等策略,解决大图像处理性能瓶颈,并确保跨浏览器兼容性和移动设备优化。实际应用案例展示了其即时处理、高质量输出和客户端隐私保护等特点。未来计划引入WebGPU加速、AI增强等功能,进一步提升用户体验。此技术栈为Web图像处理应用提供了高效可行的解决方案。
|
6月前
|
JavaScript 前端开发 开发者
JavaScript:驱动现代Web的核心引擎
JavaScript:驱动现代Web的核心引擎
|
6月前
|
JavaScript 前端开发 物联网
JavaScript:驱动现代Web的核心引擎
JavaScript:驱动现代Web的核心引擎
|
9月前
|
移动开发 前端开发 JavaScript
前端web创建命令
本项目使用 Vite 搭建 Vue + TypeScript 开发环境,并基于 HTML5 Boilerplate 提供基础模板,快速启动现代前端开发。
150 2
|
9月前
|
JSON JavaScript 前端开发
JavaScript入门干货:蓝桥杯Web组分章学习笔记(基于蓝桥云课《JavaScript基础入门》)
这是一份详尽的JavaScript学习笔记,涵盖基础到进阶内容。包括变量、运算符、数组、字符串操作,DOM/BOM事件处理,内置对象(如Array、Date、Math)用法,JSON格式解析,以及函数作用域与闭包等核心概念。同时深入探讨值类型和引用类型的差异、异常处理机制,并介绍函数高级特性如call/apply/bind方法、递归及arguments对象。代码按章节分点整理,注释细致,适合初学者系统掌握JavaScript编程知识。
167 2
|
11月前
|
前端开发 JavaScript 数据可视化
58K star!这个让网页动起来的JS库,前端工程师直呼真香!
Anime.js 是一款轻量级但功能强大的JavaScript动画引擎,它能够以最简单的方式为网页元素添加令人惊艳的动效。这个项目在GitHub上已经获得58,000+星标,被广泛应用于电商页面、数据可视化、游戏开发等场景。
418 8
|
11月前
|
存储 JavaScript 前端开发

热门文章

最新文章

  • 1
    前端如何存储数据:Cookie、LocalStorage 与 SessionStorage 全面解析
    883
  • 2
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
    403
  • 3
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
    305
  • 4
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
    278
  • 5
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
    401
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
    587
  • 7
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
    634
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(三):元素继承关系、层叠样式规则、字体属性、文本属性;针对字体和文本作样式修改
    193
  • 9
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
    544
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
    348