当前位置:首页 > 科技  > 软件

JavaScript中闭包的四个有用技巧

来源: 责编: 时间:2023-10-26 17:12:03 436观看
导读本文转载自微信公众号「黑土豆的前端博客」,作者Maybe007。转载本文请联系黑土豆的前端博客公众号。
前言当谈到JavaScript编程中的高级概念和技巧时,闭包(Closures)是一个重要而有趣的主题。闭包是一种函数与其创建时的

本文转载自微信公众号「黑土豆的前端博客」,作者Maybe007。转载本文请联系黑土豆的前端博客公众号。
kqU28资讯网——每日最新资讯28at.com

前言

当谈到JavaScript编程中的高级概念和技巧时,闭包(Closures)是一个重要而有趣的主题。闭包是一种函数与其创建时的词法环境的组合,它允许我们捕获和保留局部变量,并在函数之外使用它们。在这篇文章中,我们将深入探讨JavaScript中闭包的4种有用技巧,以及如何应用它们来解决各种问题和提高代码质量。kqU28资讯网——每日最新资讯28at.com

1. 解决循环中的问题

在JavaScript中,循环中的变量作用域问题经常会导致预期之外的结果。通常,使用var声明变量会导致循环中的变量共享相同的作用域,因此在异步操作中,这些变量可能会具有意外的值。kqU28资讯网——每日最新资讯28at.com

问题场景:kqU28资讯网——每日最新资讯28at.com

for (var i = 0; i < 3; i++) {    setTimeout(() => {        console.log(i); // 输出什么?    }, 1000 * i);}

上述代码将在1秒、2秒和3秒后分别打印出3,三次都是相同的值。这是因为setTimeout是异步的,它在循环结束后才执行,此时i的值已经是3。kqU28资讯网——每日最新资讯28at.com

解决方法:kqU28资讯网——每日最新资讯28at.com

使用闭包来保存每次迭代中的i的值:kqU28资讯网——每日最新资讯28at.com

for (var i = 0; i < 3; i++) {    ((n) => {        setTimeout(() => {            console.log(n); // 输出0、1、2        }, 1000 * n);    })(i);}

或者,更简单的方式是使用let来声明循环变量,它将在每次迭代中创建一个新的作用域:kqU28资讯网——每日最新资讯28at.com

for (let i = 0; i < 3; i++) {    setTimeout(() => {        console.log(i); // 输出0、1、2    }, 1000 * i);}

这2种方法都可以解决循环中的作用域问题。kqU28资讯网——每日最新资讯28at.com

2. 保存函数状态

闭包还可以用于实现记忆功能,通过缓存计算结果来提高性能。这在需要重复计算的函数中特别有用。kqU28资讯网——每日最新资讯28at.com

问题场景:kqU28资讯网——每日最新资讯28at.com

实现一个累加器:kqU28资讯网——每日最新资讯28at.com

let sum = 1;function add(num) {    sum += num;    return sum;}console.log(add(1));console.log(add(5));

每次调用add时,它都会将上次的值保存下来。但是这段代码有潜在的问题,那就是sum可能会被其他部分代码无意中修改。那如何解决?kqU28资讯网——每日最新资讯28at.com

解决方法:kqU28资讯网——每日最新资讯28at.com

使用闭包就可以规避上面存在的问题且可以缓存已经计算的值:kqU28资讯网——每日最新资讯28at.com

function calculator(val) {    let sum = val;    return function(num) {        sum += num;        return sum;    }}const add = calculator(1);console.log(add(1)); //2console.log(add(5)); //7

每次调用返回的函数时,它都会将传递给它的数字加到总和中,并返回新的总和。kqU28资讯网——每日最新资讯28at.com

3. 封装私有变量和属性

在过去,为了保护对象的私有变量,常常使用闭包。通过闭包,可以将变量封装在函数内部,只能通过函数暴露的接口来访问和修改。kqU28资讯网——每日最新资讯28at.com

问题场景:kqU28资讯网——每日最新资讯28at.com

function add() {    let count = 0;    count++;    console.log(count);}add(); //输出1add(); //输出1add(); //输出1

调用函数,输出的结果都是1,但是显然我们想要的效果是让count每次加1的。那如何解决呢?kqU28资讯网——每日最新资讯28at.com

解决方法:kqU28资讯网——每日最新资讯28at.com

使用闭包来封装私有变量:kqU28资讯网——每日最新资讯28at.com

function add(){    let count = 0;    function a() {        count++;        console.log(count);    }    return a;}var res = add();res() //1res() //2res() //3

add函数返回了一个闭包a,其中包含了count变量。由于count只在add函数内部定义,因此外部无法直接访问它。但是,由于a函数引用了count变量,因此count变量的值可以在闭包内部被修改和访问,这样就可以防止它被恶意修改了。kqU28资讯网——每日最新资讯28at.com

4. 函数柯里化

函数柯里化是一种将接受多个参数的函数转化为一系列接受一个参数的函数的过程。这也可以通过闭包来实现。kqU28资讯网——每日最新资讯28at.com

问题场景:kqU28资讯网——每日最新资讯28at.com

const add = (a, b, c) => {    return a + b + c;}console.log(add(2, 3, 4)); // 输出9

解决方法:kqU28资讯网——每日最新资讯28at.com

使用闭包来实现函数柯里化:kqU28资讯网——每日最新资讯28at.com

function curry(callback) {    const args = [];    return function curried(...newArgs) {        args.push(...newArgs);        if (args.length >= callback.length) {            return callback(...args);        } else {            return curried;        }    };}function add(a, b, c) {    return a + b + c;}const curriedAdd = curry(add);console.log(curriedAdd(2)(3)(4)); // 输出 9

函数柯里化使函数更加灵活,能够逐步接受参数,提高代码的可重用性和可读kqU28资讯网——每日最新资讯28at.com

总结

在本文中,我们深入探讨了JavaScript中闭包的4种有用技巧,以及如何应用它们来解决各种问题和提高代码质量。这些技巧包括解决循环中的变量作用域问题,实现记忆功能以提高性能,封装私有变量和属性,以及使用函数柯里化来提高函数的灵活性。kqU28资讯网——每日最新资讯28at.com

闭包是JavaScript中一个强大的概念,它允许我们在函数之外访问和操作局部变量,从而解决了许多常见的编程问题。虽然闭包在JavaScript中有着广泛的应用,但也需要小心使用,以避免潜在的内存泄漏问题。确保在不再需要闭包时,及时释放对其的引用,以帮助垃圾回收器正常运作。希望本文对你理解JavaScript中的闭包和如何应用它们有所帮助。kqU28资讯网——每日最新资讯28at.com

本文转载自微信公众号「黑土豆的前端博客」,可以通过以下二维码关注。转载本文请联系公众号。kqU28资讯网——每日最新资讯28at.com

kqU28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-15223-0.htmlJavaScript中闭包的四个有用技巧

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: JCStress—验证你的并发程序是否正确

下一篇: 别再学那些落后的 Web 开发技术了 !

标签:
  • 热门焦点
  • K60 Pro官方停产 第三方瞬间涨价

    虽然没有官方宣布,但Redmi的一些高管也已经透露了,Redmi K60 Pro已经停产且不会补货,这一切都是为了即将到来的K60 Ultra铺路,属于厂家的正常操作。但有意思的是该机在停产之后
  • K60至尊版刚预热 一加Ace2 Pro正面硬刚

    Redmi这边刚如火如荼的宣传了K60 Ultra的各种技术和硬件配置,作为竞品的一加也坐不住了。一加中国区总裁李杰发布了两条微博,表示在自家的一加Ace2上早就已经采用了和PixelWo
  • 0糖0卡0脂 旭日森林仙草乌龙茶优惠:15瓶到手29元

    旭日森林无糖仙草乌龙茶510ml*15瓶平时要卖为79.9元,今日下单领取50元优惠券,到手价为29.9元。产品规格:0糖0卡0脂,添加草本仙草汁,清凉爽口,富含茶多酚,保留
  • 三万字盘点 Spring 九大核心基础功能

    大家好,我是三友~~今天来跟大家聊一聊Spring的9大核心基础功能。话不多说,先上目录:图片友情提示,本文过长,建议收藏,嘿嘿嘿!一、资源管理资源管理是Spring的一个核心的基础功能,不
  • 自动化在DevOps中的力量:简化软件开发和交付

    自动化在DevOps中扮演着重要角色,它提升了DevOps的效能。通过自动化工具和方法,DevOps团队可以实现以下目标:消除手动和重复性任务。简化流程。在整个软件开发生命周期中实现更
  • 破圈是B站头上的紧箍咒

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之每年的暑期档都少不了瞄准追剧女孩们的古偶剧集,2021年有优酷的《山河令》,2022年有爱奇艺的《苍兰诀》,今年却轮到小破站抓住了追
  • 当家的盒马,加速谋生

    来源 | 价值星球Planet作者 | 归去来自己&ldquo;当家&rdquo;的盒马,开始加速谋生了。据盒马官微消息,盒马计划今年开放生鲜供应链,将其生鲜商品送往食堂。目前,盒马在上海已经与
  • 国行版三星Galaxy Z Fold5/Z Flip5发布 售价7499元起

    2023年8月3日,三星电子举行Galaxy新品中国发布会,正式在国内推出了新一代折叠屏智能手机三星Galaxy Z Fold5与Galaxy Z Flip5,以及三星Galaxy Tab S9
  • 三星获批量产iPhone 15全系屏幕:苹果史上最惊艳直屏

    按照惯例,苹果将继续在今年9月举办一年一度的秋季新品发布会,有传言称发布会将于9月12日举行,届时全新的iPhone 15系列将正式与大家见面,不出意外的话
Top