javascript - ES5的闭包用ES6怎么实现
问题描述
如何将下面的代码用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...
相关文章:
1. javascript - 使用form进行页面跳转,但是很慢,如何加一个Loading?2. python 计算两个时间相差的分钟数,超过一天时计算不对3. angular.js - 输入邮箱地址之后, 如何使其自动在末尾添加分号?4. javascript - 后台管理系统左侧折叠导航栏数据较多,怎么样直接通过搜索去定位到具体某一个菜单项位置,并展开当前菜单5. docker-machine添加一个已有的docker主机问题6. docker-compose中volumes的问题7. angular.js - angularjs 注入模块报错 很怪异... 求解惑8. javascript - ES6规范下 repeat 函数报错 Invalid count value9. javascript - html5的data属性怎么指定一个function函数呢?10. html5 - 为什么使使用vue cli 脚手架,post-css 没有自动对css3属性自动添加浏览器前缀呢?
