filter,map,reduce三个数组高阶函数的使用

filter ,map ,reduce三个高阶函数的使用

普通方法解决数据问题

  1.  const nums1= [10,20,111,222,444,40,50]
    
         // 需求1.取出小于100的数字
         // 常规思想,用一个数组保存取出的数字,遍历里面的项,小于100的追加进新数组
         let newNums = []
         for(let n of nums1){
           if(n<100){
             newNums.push(n)
           }
         }
         console.log(newNums)  
    
         // 需求2.再将所有小于100的数字进行转化:全部乘2
         let newNums2 = []
         for(let n of newNums){
           newNums2.push(n*2)
         }
         console.log(newNums2)
    
         // 需求3.再将所有数据相加
         let total =0 ;
         for(let n of newNums2){
           total +=n
         }
         console.log(total);
  2. 经过三次创建新数组和对数组的操作拿到了最终想要的数据

引入三个高阶函数

  1.     const nums2 = [10,20,111,222,444,40,50]
         // filter (数组数据过滤)
         // arr.filter( callbackfn(n) )  ->回调函数有一个要求,必须返回一个boolean值
         // 回调函数中的参数n会依此拿arr数组中的每一项
         // 当返回true的时候,函数内部会自动将这次回调的n加入到新的数组中
         // 当返回的false的时候,函数内部会过滤这次的
    
         let new1 = nums2.filter(function(n){
           return n < 100
         })
         console.log(new1);
    
         // map  (数组数据变异)
         // arr.map( callbackfn(n) ) ->回调函数与filter不同,有返回值,但是不是boolean值
         // 每次返回的值都作为内部创建的数组的项依此添加进去
         let new2 = new1.map(function(n){
           return n*2
         })
         console.log(new2);
    
         // reduce (数组数据汇总(相乘,相加))
         // arr.reduce( callbackfn (preValue , n) , num )
         // preValue上一次返回的值,n为调用该方法数组的每一项  num为perValue的初始值
         let sum = new2.reduce((preValue,n)=>{
           return preValue + n
         },0)
         console.log(sum);
    

    高阶函数的链式调用

  2.  // 链式调用
     // 高阶函数的高阶用法:因为这三个函数都会返回一个数组,那我门是不是连续使用此方法
       let sum1 = nums2.filter((n)=>{
         return n<100
       }).map((n)=>{
         return n*2
       }).reduce((e,n)=>{
         return e+n
       },0)
       console.log(sum1);

原文地址:https://www.cnblogs.com/JCDXH/p/11745153.html

时间: 2024-11-10 10:29:26

filter,map,reduce三个数组高阶函数的使用的相关文章

Spark 3000门徒第三课scala高阶函数总结

今晚听了王家林老师3000门徒spark系列课程的第三课,讲述了scala函数,下面写一下心得: 普通函数:def fun1(name:String){println(name)} 函数赋值给变量:val fun1 = functionName _ 匿名函数:val fun2 = (name:String) => prinln(name) 高阶函数:def bigData(func:(String) => Unit, content: String){func(content)} 返回值是函数

Swift 烧脑体操(三) - 高阶函数

前言 Swift 其实比 Objective-C 复杂很多,相对于出生于上世纪 80 年代的 Objective-C 来说,Swift 融入了大量新特性.这也使得我们学习掌握这门语言变得相对来说更加困难.不过一切都是值得的,Swift 相比 Objective-C,写出来的程序更安全.更简洁,最终能够提高我们的工作效率和质量. Swift 相关的学习资料已经很多,我想从另外一个角度来介绍它的一些特性,我把这个角度叫做「烧脑体操」.什么意思呢?就是我们专门挑一些比较费脑子的语言细节来学习.通过「烧

高阶组件&amp;&amp;高阶函数(一)

antd里面的form表单方面,遇到一个高阶函数,以及高阶组件,于是看了一下这方面内容,前辈们的文章写得也非常详细,这里就稍微kobe一下 高阶函数与高阶组件 高阶函数: 高阶函数,是一种特别的函数,接受的参数为函数,返回值也是函数 成立条件,二者兼一即可 1).一类特别的函数 a).接受函数类型的参数 b).函数返回值是函数 常见的高阶函数: 2).常见 a).定时器:setTimeout()/setInterval() b).Promise:Promise(()=>{}) then(valu

Scala 高阶函数(high-order function)剖析

Scala 是一种函数式编程语言,也就是说每一个函数都是一个值.Scala 有很简洁的语法用于定义匿名函数.curry 化函数(curried function).应用函数.偏函数以及嵌套函数等.函数式编程由数学函数演变得来,包含大量诸如串联与并联.组合与分离.协变与逆变等一系列概念.本文将就如何实现高阶函数进行阐述,其他部分内容不进行深究. 类型参数化协变与逆协变 类型参数化(type parameterization)由类型协变性(Type variance)补充构成,类型协变性的机制则是在

Swift高阶函数:Map,Filter,Reduce

闭包介绍 Swift一大特性便是使用简洁的头等函数/闭包语法代替了复杂的blocks语法.希望我们在Swift中不再需要像fuckingblocksyntax中所描述的语法.(译者注:头等函数-即可将函数当作参数传递给其他的函数,或从其他的函数里返回出值,并且可以将他们设定为变量,或者将他们存储在数据结构中) 闭包是自包含的blocks,它能在代码中传递和使用. 本文我们将重点介绍匿名定义的闭包(如:定义成内联的且不具名)也称匿名闭包.我们能够将其作为参数传递给其他函数/方法或者将其作为返回值.

ES6高阶函数:过滤器&gt;&gt;filter, map,reduce

1 // 高阶函数 filter/map/reduce 2 3 // filter中的回调函数有一个要求:必须返回一个boolean值, 4 // 当返回true时,函数内部会自动将这次回调的 n 加入到新的数组中 5 // 当返回false时,函数内部会自动过滤掉这次的 n 6 const nums=[10,20,60,94,348,57,24,674,645,44,4] 7 let newNums = nums.filter(function (n){ 8 return n<30 9 })

js高阶函数filter、map、reduce

1 // 高阶函数 filter/map/reduce 2 3 // filter中的回调函数有一个要求:必须返回一个boolean值, 4 // 当返回true时,函数内部会自动将这次回调的 n 加入到新的数组中 5 // 当返回false时,函数内部会自动过滤掉这次的 n 6 const nums=[10,20,60,94,348,57,24,674,645,44,4] 7 let newNums = nums.filter(function (n){ 8 return n<30 9 })

Python进阶:函数式编程(高阶函数,map,reduce,filter,sorted,返回函数,匿名函数,偏函数)...啊啊啊

函数式编程 函数是Python内建支持的一种封装,我们通过把大段代码拆成函数,通过一层一层的函数调用,就可以把复杂任务分解成简单的任务,这种分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计的基本单元. 而函数式编程(请注意多了一个"式"字)--Functional Programming,虽然也可以归结到面向过程的程序设计,但其思想更接近数学计算. 我们首先要搞明白计算机(Computer)和计算(Compute)的概念. 在计算机的层次上,CPU执行的是加减乘除的指令代码

JavaScript高阶函数 map reduce filter sort

本文是笔者在看廖雪峰老师JavaScript教程时的个人总结 高阶函数 一个函数就接收另一个函数作为参数,这种函数就称之为高阶函数 1.高阶函数之map: 此时我们有一个数组和一个接受一个参数并返回一个数的函数.我们需要把这个数组的每一个值在这个函数上走一遍,从而得到一个新数组.此时就需要map了 var a = [1,2,3,4,5,6]; var b = [] var fun = function(x) { return x * x; } b = a.map(fun) alert(b)  /