js 数组详细操作方法及解析合集(9)

  • 如果所有元素都满足条件,则返回 true。=
  • eg:

    function isBigEnough(element, index, array) { 
     return element >= 10; // 判断数组中的所有元素是否都大于10
    }
    let result = [12, 5, 8, 130, 44].every(isBigEnough); // false
    let result = [12, 54, 18, 130, 44].every(isBigEnough); // true
    // 接受箭头函数写法 
    [12, 5, 8, 130, 44].every(x => x >= 10); // false
    [12, 54, 18, 130, 44].every(x => x >= 10); // true

    some 数组中的是否有满足判断条件的元素

    定义:数组中的是否有满足判断条件的元素

    语法:

    array.some(function(currentValue, index, arr), thisValue)
    参数:(这几个方法的参数,语法都类似)

    function(必须): 数组中每个元素需要调用的函数。

    // 回调函数的参数
    1. currentValue(必须),数组当前元素的值
    2. index(可选), 当前元素的索引值
    3. arr(可选),数组对象本身

    thisValue(可选): 当执行回调函数时this绑定对象的值,默认值为undefined

    方法返回值规则:

    1. 如果有一个元素满足条件,则表达式返回true, 剩余的元素不会再执行检测。
    2. 如果没有满足条件的元素,则返回false。

    function isBigEnough(element, index, array) {
     return (element >= 10); //数组中是否有一个元素大于 10
    }
    let result = [2, 5, 8, 1, 4].some(isBigEnough); // false
    let result = [12, 5, 8, 1, 4].some(isBigEnough); // true

    filter 过滤原始数组,返回新数组

    定义: 返回一个新数组, 其包含通过所提供函数实现的测试的所有元素。

    语法:

    let new_array = arr.filter(function(currentValue, index, arr), thisArg)
    参数:(这几个方法的参数,语法都类似)

    function(必须): 数组中每个元素需要调用的函数。

    // 回调函数的参数
    1. currentValue(必须),数组当前元素的值
    2. index(可选), 当前元素的索引值
    3. arr(可选),数组对象本身

    thisValue(可选): 当执行回调函数时this绑定对象的值,默认值为undefined

    eg:

    let a = [32, 33, 16, 40];
    let result = a.filter(function (value, index, array) {
     return value >= 18; // 返回a数组中所有大于18的元素
    });
    console.log(result,a);// [32,33,40] [32,33,16,40]

    map 对数组中的每个元素进行处理,返回新的数组

    定义:创建一个新数组,其结果是该数组中的每个元素都调用一个提供的函数后返回的结果。

    语法:

    let new_array = arr.map(function(currentValue, index, arr), thisArg)
    参数:(这几个方法的参数,语法都类似)

    function(必须): 数组中每个元素需要调用的函数。

    内容版权声明:除非注明,否则皆为本站原创文章。

    转载注明出处:http://www.heiqu.com/490.html