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