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

Posted 曹豆芽

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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));

欢迎一起交流🙏🙏。

以上是关于JS循环遍历方法你知道几个?的主要内容,如果未能解决你的问题,请参考以下文章

我的公众号 - 豆芽儿 软件研发人才生长社区

我的公众号 - 豆芽儿 软件研发人才生长社区

我的公众号 - 豆芽儿 软件研发人才生长社区

我的公众号 - 豆芽儿 软件研发人才生长社区

js数组处理方法来看看?

js数组处理方法来看看?