ES6中非常实用的新特性介绍.pdf

  1. 1、本文档共3页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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)

lyf66300 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8020140062000006

1亿VIP精品文档

相关文档