js循环for、for...in、for...of、forEach 使用场景及优缺点

简介: js循环for、for...in、for...of、forEach 使用场景及优缺点
  • 普通循环 for 循环,自行指定循环次数
for(i = 0; i < loopTimes; i++) {
    console.log(i)
}
  • for...in 循环

      用于遍历对象的属性(数组的索引值也算属性), 但有一个缺点,如果手动向数组添加成员属性,则:虽然数组的length 不变,但用 for....in 遍历数组会遍历到那些新定义的属性

for (property in obj) {
    console.log(property,obj[property]);
}
  • for....of循环(ES6)

for...of 循环修复了for...in存在的问题,他只遍历属于对象本身的属性值。且这个对象必须是 iterable 可被迭代的。如Array、Map、Set。

for (element of iterable) {
    console.log(element);
}
  • forEach(callbackFn , ?thisArg)方法(ES5.1)

iterable 可被迭代的对象都是有 forEach(callbackEn,?thisArg),而Array,Map,Set 对象都是可被迭代的。forEach()接受一个回调函数 callbackFn,每次迭代都回调该函数。

回调函数的参数列表为(value,key,iterable),依次是(值,键,可迭代的对象本身)。

iterable.forEach(function(value, key, iterable) {
    console.log(key, value, iterable);
}


目录
相关文章
|
4月前
|
JavaScript 前端开发
JS循环for、for...of、for...in
本文介绍了JavaScript中不同的循环语句,包括传统的`for`循环、`for...of`循环用于遍历数组和类数组对象、`for...in`循环用于遍历对象的属性,并通过示例代码展示了它们的用法和区别。
61 6
JS循环for、for...of、for...in
|
4月前
|
前端开发 JavaScript
JavaScript 面试系列:如何理解 ES6 中 Generator ?常用使用场景有哪些?
JavaScript 面试系列:如何理解 ES6 中 Generator ?常用使用场景有哪些?
|
3月前
|
JavaScript 前端开发
js循环有几种
js循环有几种
55 0
|
2月前
|
JavaScript
js动画循环播放特效源码(上班族的一天)
js动画循环播放特效是一段实现了包含形象的卡通小人吃、睡、电脑工作的网页动画,js循环动画,简单的画面设计。非常丝滑有意思,欢迎对此代码感兴趣的朋友前来下载参考。
37 2
|
4月前
|
前端开发 JavaScript
前端基础(八)_JavaScript循环(for循环、for-in循环、for-of循环、while、do-while 循环、break 与 continue)
本文介绍了JavaScript中的循环语句,包括for循环、for-in循环、for-of循环、while循环、do-while循环以及break和continue的使用。
162 1
前端基础(八)_JavaScript循环(for循环、for-in循环、for-of循环、while、do-while 循环、break 与 continue)
|
3月前
|
前端开发 JavaScript 开发者
JS 异步解决方案的发展历程以及优缺点
本文介绍了JS异步解决方案的发展历程,从回调函数到Promise,再到Async/Await,每种方案的优缺点及应用场景,帮助开发者更好地理解和选择合适的异步处理方式。
|
4月前
|
JavaScript 前端开发 索引
|
3月前
|
JavaScript
自动循环提交js
自动循环提交js
27 0
|
4月前
|
JavaScript 前端开发
JavaScript 中 五种迭代数组的方法 every some map filter forEach
本文介绍了JavaScript中五种常用数组迭代方法:every、some、filter、map和forEach,并通过示例代码展示了它们的基本用法和区别。
|
2月前
|
JavaScript 前端开发
JavaScript中的原型 保姆级文章一文搞懂
本文详细解析了JavaScript中的原型概念,从构造函数、原型对象、`__proto__`属性、`constructor`属性到原型链,层层递进地解释了JavaScript如何通过原型实现继承机制。适合初学者深入理解JS面向对象编程的核心原理。
41 1
JavaScript中的原型 保姆级文章一文搞懂