阅读 148

JS循环遍历方法你知道几个?

JS的遍历

JS的遍历是我们使用JS常用的方法,下面是豆芽总结的常用遍历的方法,快速学习使用。

for

这是常用的最多的一种遍历方法,适用于数组和对象的遍历,可以改变原数据。可以使用break跳出遍历。

const forList = ["曹", "豆", "芽"];
for (let index = 0; index < forList.length; index++) {
    console.log(forList[index]);
}
复制代码

在这里插入图片描述

forEach

forEach只适合数组遍历,不能使用break跳出,可以使用try抛出异常终止遍历。forEach 元素、索引、原数组都可以获取。

 const forList = [1, 2, 3, 4, 5, 6, 7];
 forList.forEach((item,data,index)=>{
      console.log(item,data,index);
  })
复制代码

在这里插入图片描述

for of

for of可以使用break跳出遍历,支持数组和字符串。

const forList = ["曹", "豆", "芽"];
for (let item of forList) {
    console.log(item);
}
复制代码

在这里插入图片描述

const forData = "曹豆芽";
for(let item of forData){   
    console.log(item);
}
复制代码

在这里插入图片描述

for in

for in 返回是所有可以通过对象访问的属性,适用于对象的遍历。

let arrObj = {
     name:'曹豆芽',
     age:21
}
for(let item in arrObj){
   console.log(item);
}
复制代码

在这里插入图片描述

every

every主要检测数组所有元素是否都符合指定条件,当判断元素不满足条件,返回 false,循环中断。当所有符合条件,返回true。适用于数组。

let arrList= [
   {value: '曹豆芽' },
   {value: '黄豆芽' },
   {value: '绿豆芽' }
]
let res = arrList.every( (item, index, ary) =>{
     return item.value !== '小豆芽'
})
console.log(res) 
复制代码

在这里插入图片描述

some

some主要对数组某一个元素满足条件,满足返回true,循环中断。当所有符合条件,返回false。适用于数组。

let arrList= [
    {value: '曹豆芽' },
    {value: '黄豆芽' },
    {value: '绿豆芽' }
 ]
let res = arrList.some( (item, index, ary) =>{
     return item.value == '曹豆芽'
})
console.log(res) 
复制代码

在这里插入图片描述

map

map会生成新的数组,不会改变旧的数组。return返回新的数组,新数组和老数组的长度一致。map 生成的新数组元素是可自定义。适用于数组。

let arrList = [
   { value: '曹豆芽' },
   { value: '黄豆芽' },
   { value: '绿豆芽' }
]
let res = arrList.map((item, index, ary) => {
   return item.value = '曹豆芽'
})
console.log(res)
复制代码

在这里插入图片描述

filter

filter创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。map 生成的新数组元素是不可自定义。适用于数组。

let arrList = [
   { value: '曹豆芽' },
   { value: '黄豆芽' },
   { value: '绿豆芽' }
]
let res = arrList.filter((item, index, ary) => {
  return item.value = '曹豆芽'
  })
console.log(res)
复制代码

在这里插入图片描述

reduce

reduce存在四个参数,分别是:上一次的值,当前值,当前值的索引和当前数组。主要使用累加场景。适用于数组。

let arrList = [
            21,
            21,
            21
]
let res = arrList.reduce((previousValue, currentValue, index, array) => {
  return previousValue + currentValue
})
console.log(res)
复制代码

在这里插入图片描述

reduceRight

reduceRight的适用场景于reduce一致,只是累加从末到首累加。适用于数组。

let arrList = [
            21,
            21,
            21
]
let res = arrList.reduceRight((previousValue, currentValue, index, array) => {
     return previousValue + currentValue
})
console.log(res)
复制代码

find

find查找符合条件的数组元素,返回符合条件的第一个元素的值,。当数组返回符合条件的元素,跳出循环。适用于数组。

let arrList = [
    { value: '曹豆芽' },
    { value: '黄豆芽' },
    { value: '绿豆芽' }
]
let res = arrList.find((item, index, ary) => {
    return item.value == '曹豆芽'
})
console.log(res)
复制代码

在这里插入图片描述

findIndex

findIndex会返回数组中找到的元素的索引,如果不存在会返回-1。适用于数组。

let arrList = [
    { value: '曹豆芽' },
   { value: '黄豆芽' },
   { value: '绿豆芽' }
]
let res = arrList.findIndex((item, index, ary) => {
   return item.value == '曹豆芽'
})
console.log(res)
复制代码

在这里插入图片描述

Object.keys

Object.keys遍历获得key值,返回为数组,适用于对象。

let arrObj = {
   name:'曹豆芽',
   age:21
}
console.log(Object.keys(arrObj)); 
复制代码

在这里插入图片描述

Object.values

Object.values获取遍历的value,返回为数组,适用对象。

let arrObj = {
     name:'曹豆芽',
     age:21
}
console.log(Object.values(arrObj));
复制代码

在这里插入图片描述

Object.entries

Object.entries获取key,value,分别返回为数组,适用于对象。

let arrObj = {
    name:'曹豆芽',
    age:21
}
console.log(Object.entries(arrObj));
复制代码

在这里插入图片描述

Object.getOwnPropertySymbols

Object.getOwnPropertySymbols获取key,返回为数组,适用于对象。

let arrObj = {
    name:'曹豆芽',
    age:21
 }
console.log(Object.getOwnPropertyNames(arrObj));
复制代码

在这里插入图片描述

Reflect.ownKeys

Reflect.ownKeys获取对象key返回为数组,适用对象。

let arrObj = {
    name:'曹豆芽',
    age:21
}
console.log(Reflect.ownKeys(arrObj));
复制代码

在这里插入图片描述

欢迎一起交流🙏🙏。

文章分类
前端
文章标签