JavaScript高阶函数map/reduce、filter和sort
map()
举例说明,比如我们有一个函数f(x)=x²,要把这个函数作用在一个数组[1,2,3,4,5,6,7,8,9]上。
由于map()方法定义在JavaScript的Array中,我们调用Array的map()方法,传入我们自己的函数,就得到了一个新的Array作为结果:
  function pow(x) {
        return x*x;
    }
    var arr = [1,2,3,4,5,6,7,8,9];
    arr.map(pow);//[1,4,9,16,25,36,49,64,81]
map()传入的参数是pow,即函数对象本身。
map()作为高阶函数,事实上它把运算规则抽象了,因为,我们不但可以计算简单的f(x)=x²,还可以计算任意复杂的函数,比如Array的所有数字转为字符串:
var arr = [1,2,3,4,5,6,7,8,9];
arr.map(String);//['1','2','3','4','5','6','7','8','9']
//只需要一行代码
reduce()
再看reduce的用法,Array的reduce()把一个函数作用在这个Array的[x1,x2,x3……]上。这个函数必须接收两个参数,reduce()把结果继续和序列的下一个元素做积累计算,其效果就是
[x1,x2,x3,x4].reduce(f) = f(f(f(x1,x2),x3),x4)
比如说对一个Array求和,就可以用reduce实现:
var arr = [1,3,5,7,9];
arr.reduce(function(x,y){
return x+y;
});//
要把[1,3,5,7,9]变换成整数13579,reduce()也能派上用场:
var arr = [1,3,5,7,9];
arr.reduce(function(x,y) {
return x*10+y;
});//
filter()
filter也是一个常用的操作,它用于把Array的某些元素过滤掉,然后返回剩下的元素。
和map()类似,Array的filter()也接收一个函数。和map()不同的是,filter()把传入的函数依次作用于每个元素,然后根据返回值是true还是false决定保留还是丢弃该元素。
例如,在一个Array中,删掉偶数,只保留奇数,可以这么写:
var arr = [1,2,4,5,6,9,10,15];
var r = arr.filter(function(x) {
return x % 2 !== 0;
});
r;//[1,5,9,15]
把一个Array中的空字符串删掉,可以这么写:
var arr=['A','','B',null,undefined,'C',' '];
var r=arr.filter(function(s){
return s && s.trim();//注意,IE9版本没有trim()方法
});
r;//['A','B','C']
filter()这个高阶函数,关键在于正确实现一个“筛选”函数。
回调函数
filter()接收的回调函数,其实可以有多个参数。通常我们仅使用第一个参数,表示Array的某个元素。回调函数还可以接收另外两个参数,表示元素的位置和数组本身:
var arr = ['A','B','C'];
var r=arr.filter(function(element,index,self) {
console.log(element);//依次打印'A','B','C'
console.log(index);//依次打印0,1,2
console.log(self);//self就是变量arr
return true;
})
sort
排序算法:
排序也是在程序中经常用到的算法。无论使用冒泡排序还是快速排序。排序的核心是比较两个元素的大小。如果是数字,我们可以直接比较。但如果是字符串或者两个对象呢?直接比较数字上的大小是没有意义的,因此,比较的过程必须通过函数抽象出来。通常规定,对于两个元素x和y,如果认为x<y,则返回-1,如果x==y,则返回0,如果认为x>y,则返回1,这样,排序算法就不用关心具体的比较过程,而是根据比较的结果直接排序。
Array的sort()方法就是用于排序的。但是排序结果可能让你大吃一惊。
这是因为Array的sort()方法默认把所有元素先转换为String再排序,结果‘10’排在了‘2’的前面,因为字符‘1’比字符‘2’的ASCII码小。
如果不知道sort()方法的默认排序规则,直接对数字排序,大吃一惊。
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]
默认情况下,对字符串排序,是按照ASCII的大小比较的,现在,我们提出排序应该忽略大小写,按照字母序排序。要实现这个算法,不必对现有代码大加改动,只要我们能定义出忽略大小写的比较算法就可以:
var arr = ['Google','apple','Microsoft'];
arr.sort(function (s1,s2){
x1 = s1.toUpperCase();
x2 = s2.toUpperCase();
if(x1<x2) {
return -1;
}
if(x1>x2) {
return 1;
}
return 0;
});//['apple','Google','Microsoft']
忽略大小写来比较两个字符串,实际上就是先把字符串都变成大写(或者小写),再做比较。
高阶函数的抽象能力是非常强大的,而且,核心代码可以保持得非常简洁。
sort()方法会直接对Array进行修改,它返回的结果仍是当前Array:
var a1 = ['B','A','C'];
var a2 = a1.sort();
a1;//['A','B','C']
a2;//['A','B','C']
a1 === a2;//true,a1和a2是同一对象。
JavaScript高阶函数map/reduce、filter和sort的更多相关文章
- JavaScript高阶函数 map reduce filter sort
		本文是笔者在看廖雪峰老师JavaScript教程时的个人总结 高阶函数 一个函数就接收另一个函数作为参数,这种函数就称之为高阶函数 1.高阶函数之map: ... 
- python--函数式编程 (高阶函数(map , reduce ,filter,sorted),匿名函数(lambda))
		1.1函数式编程 面向过程编程:我们通过把大段代码拆成函数,通过一层一层的函数,可以把复杂的任务分解成简单的任务,这种一步一步的分解可以称之为面向过程的程序设计.函数就是面向过程的程序设计的基本单元. ... 
- Python 函数式编程 & Python中的高阶函数map reduce filter 和sorted
		1. 函数式编程 1)概念 函数式编程是一种编程模型,他将计算机运算看做是数学中函数的计算,并且避免了状态以及变量的概念.wiki 我们知道,对象是面向对象的第一型,那么函数式编程也是一样,函数是函数 ... 
- Python学习 Day 5 高阶函数 map/reduce filter sorter 返回函数 匿名函数 装饰器 偏函数
		高阶函数Higher-orderfunction 变量可以指向函数 >>> abs #abs(-10)是函数调用,而abs是函数本身 <built-in function ab ... 
- 函数式编程 高阶函数  map&reduce filter sorted
		函数式编程 纯函数:没有变量的函数 对于纯函数而言:只要输入确定,那么输出就是确定的.纯函数是没有副作用的. 函数式编程:允许把函数本身作为参数传入另一个函数,还允许返回一个函数 高阶函数:一个函数的 ... 
- Python高阶函数_map/reduce/filter函数
		本篇将开始介绍python高阶函数map/reduce/filter的用法,更多内容请参考:Python学习指南 map/reduce Python内建了map()和reduce()函数. 如果你读过 ... 
- 辅助函数和高阶函数 map、filter、reduce
		辅助函数和高阶函数 map.filter.reduce: 一.辅助函数:(1-1)响应式函数 (数组更新检测): push() pop() shift() unshift() ... 
- python之高阶函数map/reduce
		L = [] for n in [1, 2, 3, 4, 5, 6, 7, 8, 9]: L.append(f(n)) print(L) Python内建了map()和reduce()函数. 我们先看 ... 
- python笔记十四(高阶函数——map/reduce、filter、sorted)
		一.map/reduce 1.map() map(f,iterable),将一个iterable对象一次作用于函数f,并返回一个迭代器. >>> def f(x): #定义一个函数 ... 
随机推荐
- 腾讯刘金明:腾讯云 EB 级对象存储架构深度剖析及实践
			欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 演讲者:刘金明 腾讯云存储业务中心副总监 背景:5月23-24日,以"焕启"为主题的腾讯"云+未来" ... 
- nyoj 1205——简单问题——————【技巧题】
			简单问题 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描述 给你一个n*m的矩阵,其中的元素每一行从左到右按递增顺序排序,每一列从上到下按递增顺序排序,然后给你一些数x ... 
- SpringBoot | 第三十章:Spring-data-jpa的集成和使用
			前言 在前面的第九章:Mybatis-plus的集成和使用章节中,介绍了使用ORM框架mybatis-plus进行数据库的访问.今天,我们来简单学习下如何使用spring-data-jpa进行数据库的 ... 
- 搭建一个最简单的node服务器
			搭建一个最简单的node服务器 1.创建一个Http服务并监听8888端口 2.使用url模块 获取请求的路由和请求参数 var http = require('http'); var url = r ... 
- [SQL SERVER系列]工作经常使用的SQL整理,实战篇(二)[原创]
			工作经常使用的SQL整理,实战篇,地址一览: 工作经常使用的SQL整理,实战篇(一) 工作经常使用的SQL整理,实战篇(二) 工作经常使用的SQL整理,实战篇(三) 接着上一篇“工作经常使用的SQL整 ... 
- 【Linux】安装Nginx
			注:转自https://www.cnblogs.com/hdnav/p/7941165.html 安装所需环境 Nginx 是 C语言 开发,建议在 Linux 上运行,当然,也可以安装 Window ... 
- 数组和矩阵(1)——Find the Duplicate Number
			Given an array nums containing n + 1 integers where each integer is between 1 and n (inclusive), pro ... 
- Vector 、ArrayList、LinkedList比较
			这三者都可以随机访问,也就是支持通过索引查找数据. 都是有序(可以实现元素怎么进怎么出) Vector和ArrayList比较 相同之处 1 它们都是List 它们都继承于AbstractList,并 ... 
- Django——CBV与FBV
			一.FBV FBV(function base views) 就是在视图里使用函数处理请求. 二.CBV CBV(class base views) 就是在视图里使用类处理请求. Python是一个面 ... 
- vue+rest-framework前后端分离整合
			一.vue部分 二.django路由配置 (1)项目urls.py修改如下: from django.conf.urls import url, include urlpatterns = [ # p ... 
