
js 各循环的区别
一、原生JS
都是用于遍历数组中的每一项。 匿名函数接受 它们的 只能用于数组遍历。
发布日期:2021-05-24 12:20:59
浏览次数:13
分类:精选文章
本文共 1235 字,大约阅读时间需要 4 分钟。
for in和for of是JavaScript中用于遍历数据的两种不同方法,分别在ES5和ES6标准中首次引入。
for in方法用于遍历对象的属性。它会将所有可枚举的属性返回,但需要注意的是,这些属性可能包括从原型链上继承的属性。例如:
let obj = { a: 1 };let iterable = [3, 5, 7];iterable.foo = "hello";console.log(iterable.foo); // "hello"console.log(iterable.arrCustom); // 也会返回arrCustom吗?是的,因为它从数组的原型链中继承了这个属性。
while for of方法用于遍历具有Iterator接口的数据结构。这种数据结构如Array、Map、Set、String等都原生支持Iterator。它会逐个返回数据结构中的元素,这对于数组来说就是逐个数字,map中是每个键值对般的返回,但具体返回的格式取决于实现。
需要注意的是,从原型链继承的属性不会被for of遍历到。例如:
let iterable = [3, 5, 7];iterable.foo = "hello";for (let i of iterable) { console.log(i); // 3,5,7}
下面我们进一步讨论它们的区别以及如何在实际开发中使用它们。
一、原生JS forEach()
和 map()
遍历
共同点:
item
(当前项)、index
(当前索引)、input
(原始数组)三个参数。this
值都指向Window
对象。forEach()
的特点:
- 没有返回值。
- 适合执行一些操作,如批量修改数组中的元素。
- 例如:
var ary = [12, 23, 24, 42, 1];ary.forEach(function(item, index, input) { input[index] = item * 10;});console.log(ary); // 会显示改变后的数组:[120, 230, 240, 420, 10]
map()
的特点:
- 有返回值,可以通过
return
赋值来创建新的数组。 - 适合需要返回新数组的操作。
- 例如:
var res = ary.map(function(item, index, input) { return item * 10;});console.log(res); // [120, 230, 240, 420, 10]
在实际开发中,选择forEach
或map
取决于你是否需要修改原数组或是否需要返回一个新数组。forEach
适合执行异步操作或只要遍历,而map
适合生成新数组或依赖于回调函数的返回值。
通过这些方法,我们可以对数组进行丰富的操作,同时保持代码的简洁和可读性。
发表评论
最新留言
初次前来,多多关照!
[***.217.46.12]2025年04月12日 13时42分10秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
JS高级面向对象(二)-构造函数和原型
2019-03-15
python入门到秃顶(10):异常
2019-03-15
ES6_变量生明
2019-03-15
考研复试英语问答
2019-03-15
百度背景换肤案例
2019-03-15
修改ng-zorro中table对齐及宽度等细节
2019-03-15
输出对象的值——踩坑
2019-03-15
angular2项目里使用排他思想
2019-03-15
折线图上放面积并隐藏XY轴的线
2019-03-15
failed to push some refs to git
2019-03-15
在苹果Mac上如何更改AirDrop名称?
2019-03-15
1110 Complete Binary Tree (25 point(s))
2019-03-15
541【毕设课设】基于单片机电阻电感电容RLC测量仪系统
2019-03-15
568【毕设课设】基于单片机多路温度采集显示报警控制系统设计
2019-03-15
基于8086交通灯系统仿真设计(微机原理设计资料)
2019-03-15
解读域名管理之:域名注册机构介绍
2019-03-15
找中位数
2019-03-15
这些运维发展方向及系统运维技能都不了解,怎么能吃透Linux??
2019-03-15
自动化测试——UI自动化测试的痛点
2019-03-15
如何将萌推商品主图、属性图、详情图批量保存到电脑的方法
2019-03-15