JavaScript基础——高阶函数(map and reduce)

Posted 忍冬。

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript基础——高阶函数(map and reduce)相关的知识,希望对你有一定的参考价值。

 1     //高阶函数:一个函数可以接受另一个函数作为参数,这种函数称之为高阶函数。
 2         /*1*/
 3         function f(x,y,f){
 4             return f(x)+f(y);
 5         }
 6         var sumAbs=f(-6,4,Math.abs);
 7         console.log(sumAbs);//10
 8 
 9 
10 
11         //map和reduce
12         /*map*/
13         /*2*/
14         function pow(x){
15             return x*x;
16         }
17         var arr=[1,2,3,4,5];
18         var x2=arr.map(pow);
19         var toS=arr.map(String);
20         console.log(x2);//[1, 4, 9, 16, 25]
21         console.log(toS);//["1", "2", "3", "4", "5"]
22 
23 
24         /*reduce*/
25         /*3*/
26         var arr=[1,3,5,7,9];
27         function sum(x,y){
28             return x+y;
29         }
30         function pro(x,y){
31             return x*y;
32         }
33         function intt(x,y){
34             return x*10+y;
35         }
36         var s=arr.reduce(sum);
37         var p=arr.reduce(pro);
38         var i=arr.reduce(intt);
39         console.log(s);//25
40         console.log(p);//945
41         console.log(i);//13579
42 
43         /*or*/
44         console.log(arr.reduce(function(x,y){
45             return x+y;
46         }));//25
47             console.log(arr.reduce(function(x,y){
48             return x*y;
49         }));//945
50             console.log(arr.reduce(function(x,y){
51             return x*10+y;
52         }));//13579
53 
54 
55         /*string to int*/
56         /*4*/
57         var str="5678";
58         var arr=str.split(‘‘);
59         console.log(arr);//["5", "6", "7", "8"]
60         arr=arr.map(function(x){
61             return x-0;
62         })
63         console.log(arr);//[5, 6, 7, 8]
64         console.log(arr.reduce(function(x,y){
65             return x*10+y;//5678
66         }))
67 
68         /*or*/
69         console.log(str.split(‘‘).map(function(x){
70             return x-0;
71         }).reduce(function(x,y){
72             return x*10+y;
73         }));//5678
74 
75         
76         /*请把用户输入的不规范的英文名字,变为首字母大写,其他小写的规范名字。输入:[‘adam‘, ‘LISA‘, ‘barT‘],输出:[‘Adam‘, ‘Lisa‘, ‘Bart‘]。*/
77 
78         /*test*/
79         var str="abs";
80         console.log(str[0]);//a
81         /*5*/
82         var arr=[‘adam‘, ‘LISA‘, ‘barT‘];
83         console.log(arr.map(function(x){
84             return x[0].toUpperCase()+x.substring(1).toLowerCase()
85         }));// ["Adam", "Lisa", "Bart"]

 

以上是关于JavaScript基础——高阶函数(map and reduce)的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript高阶函数map/reducefilter和sort

JavaScript 高阶函数 map与filter的使用

JavaScript 高阶函数 + generator生成器

Python基础高阶函数

JavaScript 中的高阶函数

高阶函数