0

我的反应项目中有一些 es6 代码,如下所示:

``` javascript
for (const v of [0, 1, 2,]) { /* doSth*/ }
```

并且在传输到 es5 后运行良好。但是,如果我像这样更改它们:

``` javascript
const arr = [0, 1, 2,];
for (const v of arr) { /* doSth*/ }
```

ReferenceError: Can't find variable: Symbol然后它会在 iPhone 5c 中引发错误。我尝试了两者foreach for-in和纯for循环,它们都在那个旧设备上运行良好。但是,我需要做类似的事情async () => { for (...) { await doSthAysnc; } },它不能使用foreach。更何况,for-of本来就很危险,而且纯真for的很丑。所以如果可能的话,我更喜欢使用for-of. 谢谢。

@Bergi好吧,这就是它转换为的代码: javascript ("================================================================"),m=["a","b","c"],e.prev=38,v=c.a.mark(function e(n){return c.a.wrap(function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,new Promise(function(e){return setTimeout(function(){return e(n)},1e3)});case 2:case"end":return e.stop()}},e,t)}),y=!0,b=!1,w=void 0,e.prev=43,_=m[Symbol.iterator]();case 45:if(y=(x=_.next()).done){e.next=51;break}return E=x.value,e.delegateYield(v(E),"t2",48);case 48:y=!0,e.next=45;break;case 51:e.next=57;break;case 53:e.prev=53,e.t3=e.catch(43),b=!0,w=e.t3;case 57:e.prev=57,e.prev=58,!y&&_.return&&_.return();case 60:if(e.prev=60,!b){e.next=63;break}throw w;case 63:return e.finish(60);case 64:return e.finish(57);case 65:e.next=69;break;case 67:e.prev=67,e.t4=e.catch(38);case 69:console.log("================================================================"),

4

1 回答 1

0

直接在内部使用数组文字可以for … of实现额外的转译器优化,使其不使用可迭代对象。在默认原因中,它将尝试查找m[Symbol.iterable]在旧环境中失败的方法。

在中可以看到三个解决方案:

于 2017-09-06T06:04:22.260 回答