JS闭包的概念。。。这两个函数让我凌乱了,他们同样可以返回局部变量,但是我还是分不清区别在哪
生活随笔
收集整理的這篇文章主要介紹了
JS闭包的概念。。。这两个函数让我凌乱了,他们同样可以返回局部变量,但是我还是分不清区别在哪
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
list[i].onclick = function() {
javascript函數對象內部不僅包含函數代碼邏輯,還包含當前的作用域鏈。函數之間可以通過作用域鏈關聯起來,函數體內部的變量可以保存在函數作用域內這是閉包。第一個只不過返回了個內部變量。并沒有涉及到作用域鏈,通過作用域鏈關聯函數才是js閉包作用關鍵所在。
這個輸出是 2,因為 f2 在創建時并不會執行,而在執行時,a 已經改變了。
是第一個函數f1和第二個函數調用后返回的函數f2的區別吧我覺得區別是第一個函數返回值a是保存在這個函數里面的,第二個返回值b是保存在函數f2外面的f1里,如果在return前做一個++操作應該就能看出區別了
稍作改動
其實 第一個也是閉包,第二個是兩重閉包。。函數本身就是一個對象,同時也是一個閉包,不信你可以打開調試功能看一下。對于第二個函數中的 f2() 之所以可以訪問 b,是因為閉包內可以訪問外部變量,閉包在創建時這些變量就已經被保存了。當然,外部是不可以訪問閉包內部的變量,其實閉包用多了,自然就習慣了。
javascript函數對象內部不僅包含函數代碼邏輯,還包含當前的作用域鏈。函數之間可以通過作用域鏈關聯起來,函數體內部的變量可以保存在函數作用域內這是閉包。第一個只不過返回了個內部變量。并沒有涉及到作用域鏈,通過作用域鏈關聯函數才是js閉包作用關鍵所在。
這個輸出是 2,因為 f2 在創建時并不會執行,而在執行時,a 已經改變了。
是第一個函數f1和第二個函數調用后返回的函數f2的區別吧我覺得區別是第一個函數返回值a是保存在這個函數里面的,第二個返回值b是保存在函數f2外面的f1里,如果在return前做一個++操作應該就能看出區別了
稍作改動
其實 第一個也是閉包,第二個是兩重閉包。。函數本身就是一個對象,同時也是一個閉包,不信你可以打開調試功能看一下。對于第二個函數中的 f2() 之所以可以訪問 b,是因為閉包內可以訪問外部變量,閉包在創建時這些變量就已經被保存了。當然,外部是不可以訪問閉包內部的變量,其實閉包用多了,自然就習慣了。
總結
以上是生活随笔為你收集整理的JS闭包的概念。。。这两个函数让我凌乱了,他们同样可以返回局部变量,但是我还是分不清区别在哪的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 佛教请的圆形的符都有什么意思(圆形佛像)
- 下一篇: 香韭豆干炒肉的做法?