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

JavaScript中闭包的四个有用技巧

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

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

前言

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

1. 解决循环中的问题

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

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

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

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

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

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

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

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

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

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

2. 保存函数状态

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

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

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

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

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

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

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

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

3. 封装私有变量和属性

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

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

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

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

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

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

4. 函数柯里化

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

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

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

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

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

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

总结

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

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

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

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

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

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

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

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

标签:
  • 热门焦点
  • 轿车从天而降电动车主被撞身亡 超速抢道所致:现场视频让网友吵翻

    近日,上海青浦区法院判决轿车从天而降电动车主被撞身亡案,轿车车主被判有期徒刑一年。案件显示当时男子驾驶轿车在上海某路段行驶,前车忽然转弯提速超车,
  • 服务存储设计模式:Cache-Aside模式

    Cache-Aside模式一种常用的缓存方式,通常是把数据从主存储加载到KV缓存中,加速后续的访问。在存在重复度的场景,Cache-Aside可以提升服务性能,降低底层存储的压力,缺点是缓存和底
  • SpringBoot中使用Cache提升接口性能详解

    环境:springboot2.3.12.RELEASE + JSR107 + Ehcache + JPASpring 框架从 3.1 开始,对 Spring 应用程序提供了透明式添加缓存的支持。和事务支持一样,抽象缓存允许一致地使用各
  • 一篇聊聊Go错误封装机制

    %w 是用于错误包装(Error Wrapping)的格式化动词。它是用于 fmt.Errorf 和 fmt.Sprintf 函数中的一个特殊格式化动词,用于将一个错误(或其他可打印的值)包装在一个新的错误中。使
  • 零售大模型“干中学”,攀爬数字化珠峰

    文/侯煜编辑/cc来源/华尔街科技眼对于绝大多数登山爱好者而言,攀爬珠穆朗玛峰可谓终极目标。攀登珠峰的商业路线有两条,一是尼泊尔境内的南坡路线,一是中国境内的北坡路线。相
  • ESG的面子与里子

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之三伏大幕拉起,各地高温预警不绝,但处于厄尔尼诺大&ldquo;烤&rdquo;之下的除了众生,还有各大企业发布的ESG报告。ESG是&ldquo;环境保
  • 造车两年股价跌六成,小米的估值逻辑变了吗?

    如果从小米官宣造车后的首个交易日起持有小米集团的股票,那么截至2023年上半年最后一个交易日,投资者将浮亏59.16%,同区间的恒生科技指数跌幅为52.78%
  • 2纳米决战2025

    集微网报道 从三强争霸到四雄逐鹿,2nm的厮杀声已然隐约传来。无论是老牌劲旅台积电、三星,还是誓言重回先进制程领先地位的英特尔,甚至初成立不久的新
  • 荣耀Magic4 至臻版 首创智慧隐私通话 强劲影音系统

    2022年第一季度临近尾声,在该季度内,许多品牌陆续发布自己的最新产品,让大家从全新的角度来了解当今的手机技术。手机是电子设备中,更新迭代十分迅速的一款产品,基
Top