出自《你不知道的JavaScript》上卷
以下是本書給出的反例:
function process (data) {...}
var bigdata={...}
process(bigdata);
var btn = document.getElementById('x');
btn.addEventListener('click', function click{...});
click會被回調在其他位置, 在addEventListener函數內作為閉包函數.
但其原作用域為全局,其會保留對原作用域的引用, 故全局作用域一直存活.
以下為本書給出的正例:
function process(data) {...}
{var bigdata = {}process(bigdata)
} ∥ 子作用域塊會被回收
var btn = document.getElementById('x');
btn.addEventListener('click', function click(ev){..});
如此,使用顯式創建的作用域塊將需要回收的部分包裹,但注意不要將閉包函數需要使用的結構包裹進去,回收后會導致閉包函數無法正常工作…
以下放我自己寫的示例:
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的結構都可以放到子作用域塊回收.