[JavaScript]如何利用作用域块避免闭包内存泄漏?

出自《你不知道的JavaScript》上卷

以下是本书给出的反例:

javascript 复制代码
function process (data) {...}
var bigdata={...}
process(bigdata);
var btn = document.getElementById('x');
btn.addEventListener('click', function click{...});

click会被回调在其他位置, 在addEventListener函数内作为闭包函数.

但其原作用域为全局,其会保留对原作用域的引用, 故全局作用域一直存活.

以下为本书给出的正例:

javascript 复制代码
function process(data) {...}
{
    var bigdata = {}
    process(bigdata)
} ∥ 子作用域块会被回收
var btn = document.getElementById('x');
btn.addEventListener('click', function click(ev){..});

如此,使用显式创建的作用域块将需要回收的部分包裹,但注意不要将闭包函数需要使用的结构包裹进去,回收后会导致闭包函数无法正常工作...

以下放我自己写的示例:

javascript 复制代码
function outside(){
    let data1=[];
    {
        const data0=[1,2,3,4,5];
        data1 = data0.filter(num){
            return num > 2;
        });
     }
    return function inside(){
        return data1;
    }
}
const a = outside()();
console.log(a);

注意要用let和const.

以上把闭包需要的data1留下,其他的哪怕是用于生产data1的结构都可以放到子作用域块回收.

相关推荐
Mintopia2 小时前
四叉树:二维空间的 “智能分区管理员”
前端·javascript·计算机图形学
慌糖2 小时前
RabbitMQ:消息队列的轻量级王者
开发语言·javascript·ecmascript
Mintopia2 小时前
Three.js 深度冲突:当像素在 Z 轴上玩起 "挤地铁" 游戏
前端·javascript·three.js
MrSkye2 小时前
🔥JavaScript 入门必知:代码如何运行、变量提升与 let/const🔥
前端·javascript·面试
爱学习的茄子2 小时前
深入理解JavaScript闭包:从入门到精通的实战指南
前端·javascript·面试
zhanshuo3 小时前
不依赖框架,如何用 JS 实现一个完整的前端路由系统
前端·javascript·html
讨厌吃蛋黄酥3 小时前
智能前端新纪元:语音交互技术与安全实践全解析
javascript
1234Wu3 小时前
React Native 接入 eCharts
javascript·react native·react.js
脑袋大大的10 小时前
JavaScript 性能优化实战:减少 DOM 操作引发的重排与重绘
开发语言·javascript·性能优化
速易达网络12 小时前
RuoYi、Vue CLI 和 uni-app 结合构建跨端全家桶方案
javascript·vue.js·低代码