js新的循环
来源:互联网 发布:162端口 编辑:程序博客网 时间:2024/05/21 05:20
iterable
阅读: 184440
遍历Array
可以采用下标循环,遍历Map
和Set
就无法使用下标。为了统一集合类型,ES6标准引入了新的iterable
类型,Array
、Map
和Set
都属于iterable
类型。
具有iterable
类型的集合可以通过新的for ... of
循环来遍历。
for ... of
循环是ES6引入的新的语法,请测试你的浏览器是否支持:
用for ... of
循环遍历集合,用法如下:
var a = ['A', 'B', 'C'];var s = new Set(['A', 'B', 'C']);var m = new Map([[1, 'x'], [2, 'y'], [3, 'z']]);for (var x of a) { // 遍历Array alert(x);}for (var x of s) { // 遍历Set alert(x);}for (var x of m) { // 遍历Map alert(x[0] + '=' + x[1]);}
你可能会有疑问,for ... of
循环和for ... in
循环有何区别?
for ... in
循环由于历史遗留问题,它遍历的实际上是对象的属性名称。一个Array
数组实际上也是一个对象,它的每个元素的索引被视为一个属性。
当我们手动给Array
对象添加了额外的属性后,for ... in
循环将带来意想不到的意外效果:
var a = ['A', 'B', 'C'];a.name = 'Hello';for (var x in a) { alert(x); // '0', '1', '2', 'name'}
for ... in
循环将把name
包括在内,但Array
的length
属性却不包括在内。
for ... of
循环则完全修复了这些问题,它只循环集合本身的元素:
var a = ['A', 'B', 'C'];a.name = 'Hello';for (var x of a) { alert(x); // 'A', 'B', 'C'}
这就是为什么要引入新的for ... of
循环。
然而,更好的方式是直接使用iterable
内置的forEach
方法,它接收一个函数,每次迭代就自动回调该函数。以Array
为例:
var a = ['A', 'B', 'C'];a.forEach(function (element, index, array) { // element: 指向当前元素的值 // index: 指向当前索引 // array: 指向Array对象本身 alert(element);});
注意,forEach()
方法是ES5.1标准引入的,你需要测试浏览器是否支持。
Set
与Array
类似,但Set
没有索引,因此回调函数的前两个参数都是元素本身:
var s = new Set(['A', 'B', 'C']);s.forEach(function (element, sameElement, set) { alert(element);});
Map
的回调函数参数依次为value
、key
和map
本身:
var m = new Map([[1, 'x'], [2, 'y'], [3, 'z']]);m.forEach(function (value, key, map) { alert(value);});
如果对某些参数不感兴趣,由于JavaScript的函数调用不要求参数必须一致,因此可以忽略它们。例如,只需要获得Array
的element
:
var a = ['A', 'B', 'C'];a.forEach(function (element) { alert(element);});
阅读全文
0 0
- js新的循环
- 2.新的for循环
- For循环的新特性
- for循环的新特性
- 2.新的for循环
- js中把已知对象循环遍历出来再存入新的数组中
- js的for循环
- JS的循环语句
- js的for循环
- JS的循环语句
- js循环的demo
- js的循环语句
- js的循环遍历
- js的事件循环
- js-循环的方法
- 判断当前for循环为一层新的循环方法
- js 中的循环的实例
- JS学习 循环的学习
- 4 Values whose Sum is 0 (POJ-2785) (折半枚举)
- UVA
- 如何用Google离线API调用离线地图
- leetcode-8-String to Integer (atoi)
- beautifulsoup
- js新的循环
- oracle使用decode实现竖表转横表 (列转行)
- hdu5728PowMod
- sql 查询商品,出价最低的
- effective C++条款四十七解读
- openstack 管理四十
- 关于Android studio打包发布,以及Android签名的获取
- java 时间戳 转 字符串
- Python 面向对象编程(二)