Javascript的闭包有哪些应用?你学会了吗?

开发 前端
通过闭包,可以创建私有变量和方法。外部作用域无法直接访问闭包内的变量,从而实现了信息隐藏和封装。使用闭包可以创建模块,将相关的功能组织在一起,同时保持内部状态的私有性。

JavaScript 中的闭包是一种强大的特性,它可以用于多种应用。以下是一些闭包在 JavaScript 中的常见应用:

1、封装私有变量: 通过闭包,可以创建私有变量和方法。外部作用域无法直接访问闭包内的变量,从而实现了信息隐藏和封装。

function createCounter() {


    let count = 0;


    return function() {


        count++;


        return count;


    };


}






const counter = createCounter();


console.log(counter()); // 1


console.log(counter()); // 2

2、模块模式: 使用闭包可以创建模块,将相关的功能组织在一起,同时保持内部状态的私有性。

const Module = (function() {


    let privateVar = 0;


    function privateFunction() {


        // ...


    }


    return {


        publicVar: 1,


        publicFunction: function() {


            privateVar++;


            return privateFunction();


        }


    };


})();


console.log(Module.publicVar); // 1


console.log(Module.publicFunction()); // Result of privateFunction

3、事件处理程序: 在事件处理程序中使用闭包,可以保持对外部作用域的状态引用,而无需全局变量。

function setupEventListener() {


    let count = 0;


    document.getElementById('myButton').addEventListener('click', function() {


        count++;


        console.log(`Button clicked ${count} times.`);


    });


}


setupEventListener();

4、回调函数: 闭包经常用于创建回调函数,保存对外部函数作用域的引用,以便在稍后调用。

function doSomethingAsync(callback) {


    setTimeout(function() {


        console.log('Async operation completed.');


        callback();


    }, 1000);


}


doSomethingAsync(function() {


    console.log('Callback executed.');


});

5、实现函数记忆: 闭包可以用于缓存函数的结果,以提高性能。这通常用于递归函数或计算昂贵的操作。

function memoize(fn) {


    const cache = {};


    return function(...args) {


        const key = JSON.stringify(args);


        if (!cache[key]) {


            cache[key] = fn(...args);


        }


        return cache[key];


    };


}


const memoizedAdd = memoize(function(x, y) {


    console.log('Calculating sum...');


    return x + y;


});






console.log(memoizedAdd(2, 3)); // Calculating sum... 5


console.log(memoizedAdd(2, 3)); // 5 (from cache)

这些只是 JavaScript 中闭包的一些常见用法。闭包的灵活性使得它在许多不同的上下文中都能够发挥作用。

责任编辑:武晓燕 来源: 金木讲编程
相关推荐

2023-06-26 00:01:11

2024-02-02 11:03:11

React数据Ref

2022-07-08 09:27:48

CSSIFC模型

2024-01-02 12:05:26

Java并发编程

2023-08-01 12:51:18

WebGPT机器学习模型

2024-01-19 08:25:38

死锁Java通信

2023-07-26 13:11:21

ChatGPT平台工具

2024-02-04 00:00:00

Effect数据组件

2023-01-10 08:43:15

定义DDD架构

2022-02-12 20:45:49

AndroidPC 端工具

2024-03-18 08:06:59

JavaGo开发

2022-12-06 08:37:43

2023-01-31 08:02:18

2024-03-06 08:28:16

设计模式Java

2022-06-16 07:50:35

数据结构链表

2023-08-26 21:34:28

Spring源码自定义

2023-07-30 22:29:51

BDDMockitoAssert测试

2022-12-06 07:53:33

MySQL索引B+树

2023-10-06 14:49:21

SentinelHystrixtimeout

2022-07-13 08:16:49

RocketMQRPC日志
点赞
收藏

51CTO技术栈公众号