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

相关推荐
娃哈哈哈哈呀1 小时前
formData 传参 如何传数组
前端·javascript·vue.js
2503_928411563 小时前
11.24 Vue-组件2
前端·javascript·vue.js
g***B7384 小时前
JavaScript在Node.js中的模块系统
开发语言·javascript·node.js
Z***25804 小时前
JavaScript在Node.js中的Deno
开发语言·javascript·node.js
cypking5 小时前
Vue 3 + Vite + Router + Pinia + Element Plus + Monorepo + qiankun 构建企业级中后台前端框架
前端·javascript·vue.js
San30.5 小时前
ES6+ 新特性解析:让 JavaScript 开发更优雅高效
开发语言·javascript·es6
u***27616 小时前
TypeScript 与后端开发Node.js
javascript·typescript·node.js
星空的资源小屋6 小时前
跨平台下载神器ArrowDL,一网打尽所有资源
javascript·笔记·django
Dorcas_FE7 小时前
【tips】动态el-form-item中校验的注意点
前端·javascript·vue.js
八月ouc7 小时前
解密JavaScript模块化演进:从IIFE到ES Module,深入理解现代前端工程化基石
javascript·es6·模块化·cmd·commonjs·amd·iife