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

JavaScript中闭包的四个有用技巧

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

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

前言

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

1. 解决循环中的问题

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

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

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

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

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

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

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

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

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

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

2. 保存函数状态

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

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

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

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

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

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

使用闭包就可以规避上面存在的问题且可以缓存已经计算的值:6Ok28资讯网——每日最新资讯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

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

3. 封装私有变量和属性

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

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

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

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

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

使用闭包来封装私有变量:6Ok28资讯网——每日最新资讯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变量的值可以在闭包内部被修改和访问,这样就可以防止它被恶意修改了。6Ok28资讯网——每日最新资讯28at.com

4. 函数柯里化

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

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

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

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

使用闭包来实现函数柯里化:6Ok28资讯网——每日最新资讯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

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

总结

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

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

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

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

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

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

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

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

标签:
  • 热门焦点
  • 小米官宣:2023年上半年出货量中国第一!

    今日早间,小米电视官方微博带来消息,称2023年小米电视上半年出货量达到了中国第一,同时还表示小米电视的巨屏风暴即将开始。“公布一个好消息2023年#小米电视上半年出货量中国
  • K8S | Service服务发现

    一、背景在微服务架构中,这里以开发环境「Dev」为基础来描述,在K8S集群中通常会开放:路由网关、注册中心、配置中心等相关服务,可以被集群外部访问;图片对于测试「Tes」环境或者
  • Flowable工作流引擎的科普与实践

    一.引言当我们在日常工作和业务中需要进行各种审批流程时,可能会面临一系列技术和业务上的挑战。手动处理这些审批流程可能会导致开发成本的增加以及业务复杂度的上升。在这
  • 谷歌KDD'23工作:如何提升推荐系统Ranking模型训练稳定性

    谷歌在KDD 2023发表了一篇工作,探索了推荐系统ranking模型的训练稳定性问题,分析了造成训练稳定性存在问题的潜在原因,以及现有的一些提升模型稳定性方法的不足,并提出了一种新
  • WebRTC.Net库开发进阶,教你实现屏幕共享和多路复用!

    WebRTC.Net库:让你的应用更亲民友好,实现视频通话无痛接入! 除了基本用法外,还有一些进阶用法可以更好地利用该库。自定义 STUN/TURN 服务器配置WebRTC.Net 默认使用 Google 的
  • 认真聊聊东方甄选:如何告别低垂的果实

    来源:山核桃作者:财经无忌爆火一年后,俞敏洪和他的东方甄选依旧是颇受外界关心的&ldquo;网红&rdquo;。7月5日至9日,为期5天的东方甄选&ldquo;甘肃行&rdquo;首次在自有App内直播,
  • OPPO K11搭载高性能石墨散热系统:旗舰同款 性能凉爽释放

    日前OPPO官方宣布,将于7月25日14:30举办新品发布会,届时全新的OPPO K11将正式与大家见面,将主打旗舰影像,和同档位竞品相比,其最大的卖点就是将配备索尼
  • “买真退假” 这种“羊毛”不能薅

    □ 法治日报 记者 王春   □ 本报通讯员 胡佳丽  2020年初,还在上大学的小东加入了一个大学生兼职QQ群。群主&ldquo;七王&rdquo;在群里介绍一些刷单赚
  • 中关村论坛11月25日开幕,15位诺奖级大咖将发表演讲

    11月18日,记者从2022中关村论坛新闻发布会上获悉,中关村论坛将于11月25至30日在京举行。本届中关村论坛由科学技术部、国家发展改革委、工业和信息化部、国务
Top