- 1、本文档共3页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
ECMAScript 6 离我们越来越近了,作为它最重要的方言, Javascript 也即将迎来语法上
的重大变革, InfoQ 特开设 “深入浅出 ES6 ”专栏, 来看一下 ES6 将给我们带来哪些新内容。
写在前面
ES6 已经提交给 Ecma 大会审查了,也就是说,我们将迎来一大波 javascript 的最新
标准,还有一些语法糖。 ES6 中有很多值得我们关注的东西,下面是我发现的一些我们最
常用的一些新特性,进行记录一下。
1. for-of 循环
这个东西用来循环数组很爽,原因呢,是因为它弥补了目前 es5 中循环数组的一切缺
陷。
比如 for-in ,它会遍历数组对象的附加属性, 而不仅仅是遍历数组值。 还有一点是, for-in
中的索引是 string 类型的 ,这一点尤其重要。
var arrObj=[alexchen,1,{}];
arrObj._name=attr-AlexChen;
for(var i in arrObj){
console.log(arrObj[i]) // 会把 _name 属性也遍历出来
console.log(typeof(i)) // 全部输出 string
}
当然我们还有 forEach() 函数,它也有问题,比如你不能在里面 break return 之类的:
var arrObj = [alexchen,boy,great];
arrObj.forEach(function (v) {
if (v == boy) {
return can not return;
}
console.log(v) // 会输出 alexchen great
})
这样看起来要比 for-in 简便很多。但就像上面说的一样,它有也有不足的地方。那么
我们来试试 for-of 吧:
var arrObj = [alexchen,1,{}];
arrObj._name = attr-alexchen;
for (var i of arrObj) {
console.log(i);// 这里只会输出 ,alexchen,1,object{}, 不会输出 attr-alexchen
console.log(typeof(i))// 这里会输出 string,number,object
if (i == 1) {
break;
}
console.log(i)// 只会输出 alexchen,满足条件之后就不在继续循环,提高了效率并且可
以自由控制跳出循环或继续循环
}
可以看到:
当使用 for-of 的时候,循环的是数组内部的元素且不会出现 for-in 中将附加属性也遍
历的情况,其次,循环变量的类型和其在数组中的类型保持一致,而不是全部是 string 的
情况。
就这两点就值得我们选择 for-of 而不是 forEach() 或 for-in 当然,现在还有些浏览器
不支持。不过以上代码可以在最新版本的 FireFox 执行成功并得到预期结果。 当然 for-of 并
不是只在数组上使用,你可以用在任何类数组类型的对象上,比如 DOM NodeList , 字符
串 等
文档评论(0)