[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的结构都可以放到子作用域块回收.

相关推荐
祈澈菇凉15 分钟前
解释什么是受控组件和非受控组件
前端·javascript·react.js
徐小黑ACG39 分钟前
使用vite新建vue3项目 以及elementui的使用 vite组件问题
前端·javascript·elementui
糕冷小美n1 小时前
Electron打包文件生成.exe文件打开即可使用
前端·javascript·electron
puppy0_01 小时前
【万字长文】前端如何处理计算密集型操作(数据量10w+)
前端·javascript
Sailing1 小时前
递归陷阱:如何优雅地递归获取数据?别让你的微前端卡死!
前端·javascript·面试
前端大卫2 小时前
【Chrome 官方示例】🔥手把手教你解锁 Performace 选项卡
前端·javascript·性能优化
苏州第一深情2 小时前
SpeechSynthesisUtterance文字语音播报, 循环播报, 方法封装多组件使用, 自定义播报音色音量音调
前端·javascript·vue.js
JiangJiang2 小时前
Vue3源码:5个问题带你读懂watch
javascript·vue.js·面试
如此风景2 小时前
TypeScript中的Record
javascript
王小菲2 小时前
深入解析 JavaScript 闭包机制:从作用域到高阶应用
前端·javascript·面试