博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
面试题之js数组遍历
阅读量:5740 次
发布时间:2019-06-18

本文共 1765 字,大约阅读时间需要 5 分钟。

js中的数组遍历是项目中经常用到的,在这里将几种方法做个对比。

for循环:使用评率最高,也是最基本的一种遍历方式。

let arr = ['a','b','c','d','e'];for (let i = 0, len = arr.length; i < len; i++) { console.log(i); // 0 1 2 3 4 console.log(arr[i]); //a b c d e}复制代码

forEach()循环:forEach中传入要执行的回调函数,函数有三个参数。第一个参数为数组元素(必选),第二个参数为数组元素索引值(可选),第三个参数为数组本身(可选)

let arr = ['a','b','c','d','e'];arr.forEach((item,index,arr)=> { console.log(item); // a b c d e  console.log(index); // 0 1 2 3 4 console.log(arr); // ['a','b','c','d','e']})复制代码

map循环: map()中传入要执行的回调函数,函数有三个参数。第一个参数为数组元素(必选),第二个参数为数组元素索引值(可选),第三个参数为数组本身(可选)

var arr = [ {name:'a',age:'18'}, {name:'b',age:'19'}, {name:'c',age:'20'}];arr.map(function(item,index) { if(item.name == 'b') { console.log(index) //  }})复制代码

for...in循环:for...in循环可用于循环对象和数组,推荐用于循环对象,可以用来遍历json

let obj = { name: '前端攻城小牛', age: '864305860', //QQ群:864305860 weight: 'max'}for(var key in obj) { console.log(key); // name age weight console.log(obj[key]); // 全栈开发交流群 QQ群:864305860 max}let arr = ['a','b','c','d','e'];for(var key in arr) { console.log(key); // 0 1 2 3 4 返回数组索引 console.log(arr[key]) // a b c d e}复制代码

for...of循环:可循环数组和对象,推荐用于遍历数

for...of提供了三个新方法:

  1. key()是对键名的遍历;
  2. value()是对键值的遍历;
  3. entries()是对键值对的遍历;
let arr = ['前端攻城狮', '全栈开发交流群', 'QQ群:864305860'];for (let item of arr) {  console.log(item); // 前端攻城狮 全栈开发交流群 QQ群:864305860}// 输出数组索引for (let item of arr.keys()) {  console.log(item); // 0 1 2}// 输出内容和索引for (let [item, val] of arr.entries()) {  console.log(item + ':' + val); // 0:前端攻城狮 1:全栈开发交流群 2:Q群:864305860}复制代码

总结:forEach、map、filter、reduce、every、some 都会有 break 和 continue 不生效的问题,因为是在function中,但function解决了闭包陷阱的问题;要使用 break、continue 可以使用 for、for...in、for...of、while。 用于遍历数组元素使用:for(),forEach(),map(),for...of 用于循环对象属性使用:for...in

转载于:https://juejin.im/post/5bc5b379e51d450e99437d53

你可能感兴趣的文章
R语言数据分析利器data.table包 —— 数据框结构处理精讲
查看>>
Serilog记录MongoDB日志报错:requires the binary sub type to be UuidLegacy, not UuidStandard
查看>>
Java中/r和/n的区别
查看>>
bzoj 1009: [HNOI2008]GT考试
查看>>
I wrote a JSONHelper extension
查看>>
hello ROR第一个WEB页面
查看>>
通过 Xshell 5 连接 centOS 7 服务器
查看>>
11.24作业3
查看>>
Django中的信号
查看>>
为cocos2d-x 添加启动数字输入法的功能
查看>>
vue-element-table-js去重合并单元格解析【实战需求】
查看>>
white-space 属性设置如何处理元素内的空白
查看>>
uedit 富文本编辑器 图片上传 图片服务器
查看>>
什么是有监督学习和无监督学习
查看>>
ThreadLocal和ThreadLocalMap源码分析
查看>>
8.27 题解
查看>>
AFNetworking 下载文件断点续传操作
查看>>
Linux定时器
查看>>
JS数组分页
查看>>
云时代,程序员将面临的分化
查看>>