卓尔高考网

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

篇首语:本文由小编为大家整理,主要介绍了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 元素、索引、原数组都可以获取。

nS。JSzHuoer。COm

 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

nS。JSzHuoer。COm

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

let arrObj =      name:"曹豆芽",     age:21for(let item in arrObj)   console.log(item);

every

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

nS。JSzHuoer。COm

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:21console.log(Object.keys(arrObj)); 

Object.values

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

nS。JSzHuoer。COm

let arrObj =      name:"曹豆芽",     age:21console.log(Object.values(arrObj));

Object.entries

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

nS。JSzHuoer。COm

let arrObj =     name:"曹豆芽",    age:21console.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:21console.log(Reflect.ownKeys(arrObj));

欢迎一起交流🙏🙏。

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

您可能还会对下面的文章感兴趣: