forEach()
首先说一下foreach有的也叫增强for循环,foreach其实是for循环的一个特殊简化版。
let arr = ['a', 'b', 'c', 'd']
arr.forEach(function (val, idx, arr) {
console.log(val + ', index = ' + idx) // val是当前元素,index当前元素索引,arr数组
console.log(arr)
})
map()
map()方法返回一个新数组,数组中的元素为原始数组元素调用函数处理的后值。
map()方法按照原始数组元素顺序依次处理元素。
arr.map(function(currentValue,index,arr),thisValue)
参数说明
function(currentValue,index,arr)
必须,函数,数组中的每个元素都会执行这个函数函数参数
函数参数
currentValue 必须 当前元素值
index 可选 当前元素的索引值
arr 可选 当前元素属于的数组对象。
filter()
filter() 方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。
var newarr = [
{ num: 1, val: 'ceshi', flag: 'aa' },
{ num: 2, val: 'ceshi2', flag: 'aa2' }
]
console.log(newarr.filter(item => item.num===2 ))
reduce()
reduce() 方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。
reduce() 可以作为一个高阶函数,用于函数的 compose。
let numbers = [1,2,3,4,5]
var sum=numbers.reduce(function(s,item,index){
return s+=item
},0)//注意这个0为设置的默认值
console.log(sum)
some()
判断数组中所有的属性只要有一个符合条件 全部符合返回true 有一个不符合返回false
let arr=[1,2,3,4,5,6]
var arr2=arr.some(function(item,index){
return item<10
})
console.log(arr2)//true
every()
every 判断数组中所有的属性是否都符合条件 全部符合返回true 有一个不符合返回false
let arr=[1,2,3,4,5,6] var arr2=arr.some(function(item,index){ return item<10 }) console.log(arr2)//true
flat()
用于将嵌套的数组“拉平"变成一维数组,返回一个新数组,对原数据没有影响
[1, 2, [3, [4, 5]]].flat()
// [1, 2, 3, [4, 5]]
默认为一层、如果想要“拉平”多层的嵌套数组,可以将flat()方法的参数写成一个整数
[1, 2, [3, [4, 5]]].flat(2)
// [1, 2, 3, 4, 5]
如果不管有多少层嵌套,都要转成一维数组,可以用Infinity关键字作为参数
[1, [2, [3]]].flat(Infinity)
// [1, 2, 3]
如果原数组有空位,flat()方法会跳过空位
[1, 2, , 4, 5].flat()
// [1, 2, 4, 5]
indexOf()
查找某个元素的索引值,若有重复的,则返回第一个查到的索引值若不存在,则返回 -1
let arr = [1,2,3,4,5,2]
let arr1 = arr.indexOf(2)//1
let arr1 = arr.indexOf(10)//-1
from()
将伪数组变成数组,就是只要有length的就可以转成数组
let str = '12345'
console.log(Array.from(str)) // ["1", "2", "3", "4", "5"]
let obj = {0:'a',1:'b',length:2}
console.log(Array.from(obj)) // ["a", "b"]