• JS高阶函数的使用


    高阶函数是对其他函数进行操作的函数,可以将它们作为参数或通过返回它们。简单来说,高阶函数是一个函数,它接收函数作为参数或将函数作为输出返回。

    简单一张图,方便理解全文。

    常见的高函数:

    1、filter过滤函数

    filter也是一个常用的操作,它用于把Array的某些元素过滤掉,然后返回剩下的元素。

    filter把传入的函数依次作用于每个元素,然后根据返回值是true还是false决定保留还是丢弃该元素。

    const nums = [2,3,5,1,77,55,100,200];
    let newArray = nums.filter(function (n) {
        //小于100就是true,进入newArray数组
        return n < 100;
    })
    console.log(newArray);//[2,3,5,1,77,55]

    2、map高阶函数

    map函数同样会遍历数组每一项,传入回调函数为参数,num是map遍历的每一项,回调函数function返回值会被添加到新数组中

    const nums = [2,3,5,1,77,55,100,200];
    let new2Array = nums.map(function (num) {
        return n*2;//每过元素都乘2
    })
    console.log(new2Array);//[4,6,10,2,154,110,200,400];

    3、reduce高阶函数

    reduce函数同样会遍历数组每一项,传入回调函数和‘0’为参数,0表示回调函数中preValue初始值为0,回调函数中参数preValue是每一次回调函数function返回的值,currentValue是当前值

    const nums = [2,3,5,1,77,55,100,200];
    
    let new3Array = nums.reduce(function (preValue,currentValue) {
        //数组为[2,3,5,1,77,55,100,200],则回调函数第一次返回值为0+2=2,第二次preValue为2,返回值为2+3=5,以此类推直到遍历完成
        return preValue+currentValue;
    },0);//第二个参数0是preValue的初始值
    console.log(new3Array);//443

    4、sort排序算法

    因为Array的sort()方法默认把所有元素先转换为String再排序,结果'10'排在了'2'的前面,因为字符'1'比字符'2'的ASCII码小。如果不知道sort()方法的默认排序规则,直接对数字排序,绝对栽进坑里!

    //要按数字大小排序,我们可以这么写:
    var arr = [10, 20, 1, 2];
    arr.sort(function (x, y) {
        if (x < y) {
            return -1;
        }
        if (x > y) {
            return 1;
        }
        return 0;
    }); // [1, 2, 10, 20]
    
    //如果要倒序排序,我们可以把大的数放前面:
    var arr = [10, 20, 1, 2];
    arr.sort(function (x, y) {
        if (x < y) {
            return 1;
        }
        if (x > y) {
            return -1;
        }
        return 0;
    }); // [20, 10, 2, 1]

     

  • 相关阅读:
    powershell网络钓鱼获取用户密码
    js 倒计时(转)
    TFS如何设置在客户端独占签出
    TFS 2010 配置的时候,提示TF255466错误
    浅谈Dynamic 关键字系列之一:dynamic 就是Object(转)
    js替换字符串中全部“-”
    苹果safari浏览器登陆时Cookie无法保存的问题
    IIS发布网站出现“未能加载文件或程序集“System.Data.SQLite”或它的某一个依赖项。”的解决方法
    Aspose.Cells单元格转换为数字格式
    SQL Server中GO的使用方法(转)
  • 原文地址:https://www.cnblogs.com/bushui/p/12213689.html
Copyright © 2020-2023  润新知