本文对一个循环分享的这么详细,相信看完你会有所收获。下面话不多说,来看看详细的介绍吧。
在ECMAScript5(简称 ES5)中,有三种 for 循环,分别是:
简单for循环 for-in forEach在2015年6月份发布的ECMAScript6(简称 ES6)中,新增了一种循环,是:
for-of下面我们就来看看这 4 种 for 循环。
简单 for 循环
下面先来看看大家最常见的一种写法:
const arr = [1, 2, 3];for(let i = 0; i < arr.length; i++) { console.log(arr[i]);}
当数组长度在循环过程中不会改变时,我们应将数组长度用变量存储起来,这样会获得更好的效率,下面是改进的写法:
const arr = [1, 2, 3];for(let i = 0, len = arr.length; i < len; i++) { console.log(arr[i]);}
for-in
通常情况下,我们可以用 for-in 来遍历一遍数组的内容,代码如下:
const arr = [1, 2, 3];let index;for(index in arr) { console.log("arr[" + index + "] = " + arr[index]);}
一般情况下,运行结果如下:
arr[0] = 1arr[1] = 2arr[2] = 3
但这么做往往会出现问题。
for-in 的真相
for-in 循环遍历的是对象的属性,而不是数组的索引。因此, for-in 遍历的对象便不局限于数组,还可以遍历对象。
例子如下:
const person = { fname: "san", lname: "zhang", age: 99};let info;for(info in person) { console.log("person[" + info + "] = " + person[info]);}
结果如下:
person[fname] = sanperson[lname] = zhangperson[age] = 99
需要注意的是, for-in 遍历属性的顺序并不确定,即输出的结果顺序与属性在对象中的顺序无关,也与属性的字母顺序无关,与其他任何顺序也无关。
Array 的真相
Array 在 Javascript 中是一个对象, Array 的索引是属性名。事实上, Javascript 中的 “array” 有些误导性, Javascript 中的 Array 并不像大部分其他语言的数组。首先, Javascript 中的 Array 在内存上并不连续,其次, Array 的索引并不是指偏移量。实际上, Array 的索引也不是 Number 类型,而是 String 类型的。我们可以正确使用如 arr[0] 的写法的原因是语言可以自动将 Number 类型的 0 转换成 String 类型的 “0″ 。所以,在 Javascript 中从来就没有 Array 的索引,而只有类似 “0″ 、 “1″ 等等的属性。有趣的是,每个 Array 对象都有一个 length 的属性,导致其表现地更像其他语言的数组。但为什么在遍历 Array 对象的时候没有输出 length 这一条属性呢?那是因为 for-in 只能遍历“可枚举的属性”, length 属于不可枚举属性,实际上, Array 对象还有许多其他不可枚举的属性。
新闻热点
疑难解答
图片精选