数组方法

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

你可能感兴趣的:(数组方法)