Javascript中4个for循环的保姆级讲解
下面我们会为大家详细讲解一下这四种for循环类型,分析不同循环类型的区别与用途,希望可以帮助到正在学习JS循环的朋友。
一、for循环的类型
除去在ES5中原有的三个循环,2015年6月,ES6中又新增了一个循环类型。所以现在JS中一共有4个
作为一个前端开发工作者,你对for循环肯定不会感到陌生。我们在使用JS做项目时,经常会需要用到循环去解决问题,而for循环又是JS循环中非常重要的部分。但是你真的了解for循环吗?你知道for循环应该如何运用吗?
下面我们会为大家详细讲解一下这四种for循环类型,分析不同循环类型的区别与用途,希望可以帮助到正在学习JS循环的朋友。
一、for循环的类型
除去在ES5中原有的三个循环,2015年6月,ES6中又新增了一个循环类型。所以现在JS中一共有4个循环类型,分别是:for、for...in、forEach、for...of。
二、4种for循环的详解
1、for循环
for循环是根据数组的长度去确定循环次数的,而对象是没有长度这个属性的,所以,for循环不能用来遍历对象,可以用来遍历数组和字符串。
for (i = 0; i
console.log(i);
}
2、For...in循环
for...in循环也是JS常用的循环方式,可以遍历对象的属性,而不是数组的索引。所以for-in遍历的对象不限于数组,也可以遍历对象。由于for...in每次都需要搜索实例和原型属性,所以在性能上要比其他循环类型性能低,并且自身参数值是数组下标。适用于Array和Object。
for (property in obj) {
console.log(property, obj[property]);
}
注意的是for-in遍历属性的顺序是不确定的,即输出结果的顺序与对象中属性的顺序无关,也与属性的字母顺序无关,也没有任何其他顺序。
3、for...of循环
for…of 语句在可迭代对象(包括 Array,Map,Set,string,TypedArray,arguments 对象等等)上创建一个迭代循环,调用自定义迭代钩子,并为每个不同属性的值执行语句。for...of循环直接用来遍历属性值,不是遍历键名和下标。
ES6 之前的 3 种 for 循环都各有缺点,forEach 不能中断和返回;for-in不仅遍历数组中的元素,还遍历自定义属性,甚至访问原型链上的属性,此外,遍历数组元素的顺序可以是随机的。因此,我们需要对原来的for循环做改进。但是,通过修复 for-in 循环来添加数组遍历支持会使这一切变得更加混乱,因此标准委员会在 ES6 中添加了一个新的循环语法来解决这些问题,那就是for...of 。
for (element of iterable) {
console.log(element);
}
4、forEach循环
forEach() 方法用于调用数组的每个元素,并将元素传递给回调函数。针对可迭代对象(Array, Map, Set, arguments等)。需要注意的是 forEach() 对于空数组是不会执行回调函数的。
iterable.forEach(function(value, key, iterable) {
console.log(key, value, iterable);
});
三、for循环与for...in、forEach的对比
1、for 与 for…in的对比
标准for循环中i为 number 类型,而 for…in中,i 表示的是数组的 key 是string类型,因为js中一切皆为对象。
for…in 方法在遍历过程中会访问原型上的所有属性,如果扩展了js原生的Array类,则会影响遍历结果。因此建议不要用for in遍历数组,采用标准的for循环变量数组。同时,如果要对js的原生类扩展的时候,不要采用prototype。
2、for与forEach的对比
① 比起传统for循环,forEach不需要判断条件和计数器,写起来更加简便
② forEach 方法没办法使用 break 语句跳出循环,或者使用return从函数体内返回
四、总结
1、for循环遍历数据的长度,根据下标获取到对应元素,不能遍历对象(对象没有长度这个属性)
2、for...in循环对于对象来说,遍历对象的键名,对于数组和字符串来说,遍历属性的长度,一般用于遍历对象
3、for...of直接遍历数据的属性值,遍历对象会报错。
4、forEach循环只能用于遍历数组,三个参数分别为属性值、属性值下标、数据源。
详解JS中常见的5 种 for 循环
for 循环在平时开发中使用频率最高的,前后端数据交互时,常见的数据类型就是数组和对象,处理对象和数组时经常使用到 for 遍历,因此需要彻底搞懂这 5 种 for 循环。它们分别为:
1、for
for 循环是出现最早,也是应用最普遍的一个遍历,能够满足绝大多数的遍历。可以遍历 数组、对象、字符串,示例:
2、for ... in
for ... in 是在 ES5 中新增的,以任意顺序迭代一个对象的除Symbol以外的可枚举属性,包括继承的可枚举属性。
3、for ... of
for ... of 语句在可迭代对象(包括 Array、Map、Set、String、TypedArray、arguments 对象等等)上创建一个迭代循环,调用自定义迭代钩子,并为每个不同属性的值执行语句。
4、for await...of
创建一个循环,该循环遍历异步可迭代对象以及同步可迭代对象,包括内置的 String、Array,类数组对象(arguments 或 nodeList),TypedArray, Map, Set 和用户定义的异步/同步迭代器。
它使用对象的每个不同属性的值调用要执行的语句来调用自定义迭代钩子。
类似于 await 运算符一样,该语句只能在一个async function 内部使用
5、forEach
forEach 是ES5版本发布的,按升序为数组中含有效值的每一项执行一次回调函数,那些已删除或者未初始化的项将被跳过(例如在稀疏数组上),一般认为是 普通for循环 的加强版。
6、map
遍历时可以返回一个新数组,新数组的结果是原数组中每个元素都调用一次提供的函数后返回的值。
1、使用场景差异
for循环是最早最原始的循环遍历语句,for 内部定义一个变量,按照条件进行循环遍历,通常是数组的长度,当超过长度时就停止循环,一般遍历的都是数组或类数组。
遍历对象时,由于对象没有长度,所以使用 Object.keys() 获取对象的所有属性,以数组形式返回。
for / in主要是用来遍历对象上的可枚举属性,包括原型对象上的属性,按任意顺序进行遍历,遍历对象时获取到的是属性的键值,遍历的是数组,数组的下标当做键值。
for / of用于遍历可迭代对象的数据,包括 Array、Map、Set、String、TypedArray、arguments 对象等等。
for await...of用于遍历异步可迭代对象,该语句只能在一个async function 内部使用。
forEach 是 for 的加升级版,使用更简单,携带参数更多,但本质还是数组的循环,每个元素都执行一次回调,不会改变原数组。
map是给原数组每个元素都执行一次回调,返回一个新数组,不会改变原数组。
2、功能差异
forEach、map 不支持跳出循环,其他不支持。
for await ... of 能够支持异步操作,其他的不支持。
对于纯对象的遍历, for ... in 枚举更方便。
对于数组遍历,如果不需要索引,可以直接使用 for...of 获取值,还可支持 break 或 return ;如果还需要索引,使用 forEach 更适合,但不支持 return。
如果是一个数组映射成另一个数组,使用 map 最合适。
3、性能差异
在测试环境、测试数据条件一致的情况下,性能排序为:
for > for of > forEach > map > for in。
for 因为没有额外的函数调用和上下文,所以性能是最快的。
for ... of 具有 iterator 接口的数据结构,可以使用它来迭代成员,直接读取键值。
forEach 是 for 的语法糖,还有许多的参数和上下文,因此会慢一些。
map 因为它返回的是一个等长的全新数组,数组创建和赋值产生的性能开销较大。
for...in 性能最差,因为需要列举对象的所有属性,有转化过程,开销比较大。
在项目开发中,我们应该根据实际需求,去选择一个合适的 for 遍历。以下是一些使用建议:
如果需要把数据映射成另外一个数组,如变成对应布尔值,推荐使用 map ,不会修改原数组,使用语法简单。
数组遍历时,可以使用 for 、forEach 或 for...of。
遍历的是纯对象时,推荐使用 for ... in 。
如果是需要对迭代器遍历,推荐使用 for ... of。
如果是在数组中筛选符合条件的数组,使用 fillter 。
这个c语言程序中的4个for语句是怎么循环的求详细解释,
第一个for,说明这个数组是三行,所以要循环三次;然后里面嵌套了一个for,说明每行有两个数据。
所以现执行i=0;k=0;k=1;
再执行i=1;k=0;k=1;
最后执行k=2;k=0;k=1;
这样输入的循环就结束了。
下面的两个循环和上面的一样,只是输出变为输出了。输出3*2的数组。
文章评论