数组方法
2019-11-24 本文已影响0人
Yin先生
1.数组合并
考虑如下场景:有多个数组,需要合并起来成为一个数组。我们可以迭代各个数组,然后把每个元素加入最终的数组。JavaScript已经给我们提供了解决方法,叫做concat方法。
const zero = 0;
const positiveNumbers = [1,2,3];
const negativeNumbers = [-3,-2,-1];
let numbers = negativeNumbers.concat(zero,positiveNumbers);
console.log(numbers); // -3, -2, -1, 0, 1, 2, 3
concat方法可以向一个数组传递数组、对象或是元素。数组会按照该方法传入的参数顺序连接指定数组。在这个例子里,zero将被合并到nagativeNumbers中,然后positiveNumbers继续被合并。最后输出的结果是 : -3, -2, -1, 0, 1, 2, 3
2.迭代器函数
有时我们需要迭代数组中的元素。我们也可以用for语句来完成。
JavaScript内置了许多数组可用的迭代方法。对于本节的例子,我们需要一个数组和一个函数:假设数组中的值是从1到15;如果数组里的元素可以被2整除(偶数),函数就返回true,否则返回false.
function isEven(x){
// 如果x是2的倍数,就返回true.
console.log(x);
return x % 2 === 0 ? true : false;
}
return(x % 2 === 0) ? true : false 也可以写成 return ( x % 2 === 0)
为了简化代码,我们可以使用箭头函数来改写isEven函数。
const isEven = x => x % 2 === 0;
2.1用every方法迭代
我们要尝试的第一个方法是every。every方法会迭代数组中的每个元素,直到返回false.
number.every(isEven);
在这个例子里,数组number的第一个元素是1,它不是2的倍数(1是奇数),因此isEven函数返回false,然后every执行结束。
every()方法,针对数组中的每一个元素进行比对,只要有一个元素比对结果为false则返回false,反之要所有的元素比对结果为true才为true
var a = [1,2,3,4,5,6];
var b = a.every(function(x){
return x < 8;
});
var c = a.every(function(x){
return x < 5;
})
console.log(b); //这里返回true
console.log(c); //这里返回false
2.2用some方法迭代
some()方法,同样是针对数组中的每一个元素,但是这个方法是,只要有一个元素比对结果为true,返回结果就为true,反之要所有的元素比对结果为false才为false
var a = [1,2,3,4,5,6]
var b = a.some(function(x){
return x > 10;
})
var c = a.some(function(x){
return x > 5;
})
console.log(b) //这里返回false
console.log(c) //这里返回true
https://blog.csdn.net/lifangfang0607/article/details/88916057