javascript - ES5的閉包用ES6怎麼實現
三叔
三叔 2017-06-30 09:59:41
0
6
951

如何將下面的程式碼用es6的let實現,

for(var i = 0; i < 3;i++) {
    (function(j){
        $.ajax({
            url: 'xxx',
            success: function(){
                console.log(j);
            }
        })(i);
    })
}
三叔
三叔

全部回覆(6)
我想大声告诉你

題主想問的是,在ES6怎麼解決i不是當前的i`的問題吧?

ES5中是使用閉包來解決的,在ES6中可以用let

for(let i = 0; i < 3;i++) {
    $.ajax({
        url: 'xxx',
        success: function(){
            console.log(i);
        }
    });
}
学习ing

這個用 ES6 也是一樣的啊,閉包還是閉包。

世界只因有你

var 換成 let

for(let i = 0; i < 3;i++) {
    $.ajax({
        url: 'xxx',
        success: function(){
            console.log(j);
        }
    })
}

測試如下(用setTimeout模擬非同步請求):

for(var i = 0; i < 3;i++) {
  setTimeout(function(){
    console.log(i)
  }, 123)
}

印3個3

es5用閉包解決

for(var i = 0; i < 3;i++) {
  (function(i) {
    setTimeout(function(){
      console.log(i)
    }, 123)
  })(i)
}

es6用let就簡單了

for(let i = 0; i < 3;i++) {
  setTimeout(function(){
    console.log(i)
  }, 123)
}

let 允許你宣告一個作用域被限制在區塊層級中的變數、語句或表達式

阿神

我也找到答案了,ES6可以直接去掉閉包

for(let i = 0; i < 3;i++) {
    $.ajax({
        url: 'xxx',
        success: function(){
            console.log(i);
        }
    });
}

這樣跟用閉包的結果是一樣的了,謝謝各位

Ty80

完全沒有必要了在ES6,直接let搞定
http://www.softwhy.com/articl...

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板