js 闭包示例
function foo() {var a=2;function bar() {console.log(a); }return bar;
}var c = foo();
c();
這里會輸出2? 熟悉閉包的都知道? 這邊是為了自己再度認真總結(jié)下:
一般來說函數(shù)執(zhí)行完以后其內(nèi)容(作用域的內(nèi)容)會被垃圾回收,但是閉包可以阻止其被回收,導致上面的c變量依舊能引用foo函數(shù)的作用域.
?
一個小例子:
for (var i = 1; i <= 5; i++) {setTimeout(function () {console.log(i);},i*1000);}很多人會認為會分別輸出1-5的數(shù)字,然而事實是會輸出5個6.6是哪來的,最后一次循環(huán)之前累加到的6.
首先這里的延遲函數(shù)是在循環(huán)之后執(zhí)行的,并且里面的閉包函數(shù)的作用域是獨立的5個作用域,但是它們都共享外部作用域? 所以會輸出5個6;
想要依次輸入1-5,可以這樣改動:
for (var i = 1; i <= 5; i++) {(function (j) {setTimeout(function () {console.log(j);},j*1000);})(i)}這里延遲函數(shù)所處的作用域是獨立不共享的,所以這里也不會去引用i變量,js接受參數(shù)時候會創(chuàng)建副本,所以j是每次迭代計算出的i的副本。
也可以用let來聲明i變量,解決上面的問題.
?
轉(zhuǎn)載于:https://www.cnblogs.com/tudou1223/p/9863346.html
總結(jié)
- 上一篇: mysql,简单介绍一下索引
- 下一篇: c++常见操作的模板