您的位置:首页技术文章
文章详情页

javascript - ES5的闭包用ES6怎么实现

【字号: 日期:2023-04-16 18:03:32浏览:46作者:猪猪

问题描述

如何将下面的代码用es6的let实现,

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

问题解答

回答1:

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

题主想问的是,在ES6中怎么解决i不是当前的i`的问题吧?

在ES5中是使用闭包来解决的,在ES6中可以用let

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

这个用 ES6 也是一样的啊,闭包还是闭包。

回答4:

把 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 允许你声明一个作用域被限制在块级中的变量、语句或者表达式

回答5:

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

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

这样跟用闭包的结果是一样的了,谢谢各位

回答6:

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

标签: JavaScript
相关文章: