ES6学习——新的语法:for..of 循环

73 篇文章 23 订阅

for...of循环是ES6中新加的一种遍历迭代器的语法。看规范中的一种形式描述,在13.7.5章节,我删了一些不重要的部分:

IterationStatement : for ( var ForBinding of AssignmentExpression ) Statement
1. Let keyResult be the result of performing ForIn/OfHeadEvaluation( « », AssignmentExpression, iterate).
2. ReturnIfAbrupt(keyResult).
3. Return ForIn/OfBodyEvaluation(ForBinding, Statement, keyResult, varBinding, labelSet).


13.7.5.12
The abstract operation ForIn/OfHeadEvaluation is called with arguments TDZnames, expr, and iterationKind. The value of iterationKind is either enumerate or iterate.

3. Let exprRef be the result of evaluating the production that is expr.
4. Set the running execution context’s LexicalEnvironment to oldEnv.
5. Let exprValue be GetValue(exprRef).
6. ReturnIfAbrupt(exprValue).
7. If iterationKind is enumerate, then
8. Else,
    a. Assert: iterationKind is iterate.
    b. Return GetIterator(exprValue).


通过上面的描述可以看出,of后面的表达式需要是个iterator。


for...of可以直接遍历数组,字符串,arguments,集合等等,在of之前还可以使用解构语法。

for(let a of [1,2,3,4])console.log(a)

for(let b of "abc")console.log(b)


解构语法如下:
let arr1 = [[1,'a'],[1,'a',true],[1,'a']];
for(let [idx,val,other] of arr1)//数组解构
  console.log(idx,val,other)
  
  
let arr2 = [{key:1,value:'a'},{key:1,value:'a',other:true}];
for(let {key:idx,value:val,other} of arr2)//对象解构
  console.log(idx,val,other)
上面的解构中不能应用默认值语法,否则会报错。


最后看看for...of遍历Symbol.iterator实现的迭代器

Object.prototype[Symbol.iterator] = function(){
		let index = 0;
		let propKeys = Reflect.ownKeys(obj);
		return {
			next() {
				if (index < propKeys.length) {
					let key = propKeys[index];
					index++;
					return { value: [key, obj[key]] };
				} else {
					return { done: true };
				}
			}
		}
	}
	
var obj = {key1:1,key2:2,[Symbol()]:"s1"};
for(let v of obj)console.log(v)


结果:


如果我们直接遍历obj,会报错:

var obj = {key1:1,key2:2,[Symbol()]:"s1"};
 for(let v of obj)console.log(v)
//TypeError: obj[Symbol.iterator] is not a function

*以上全部代码在Firefox 43下通过测试

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值