关于JavaScript中map和reduce的分析

以前看js都是云里雾里的,后来学了一些Java感觉稍微能看懂一些,恰逢又回头看到了以前关于js在有道云上的一些笔记,决定做一个关于map和reduce的分析

map

  • map一般来说针对数组进行操作。但是进行了一个很好的封装使得读者可以清晰的看到被操作数组,以及对数组内每个元素进行操作的函数。我们先看一个小例子:
var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];


/*1*/
arr.map(function{
    return x * x;
}); // [1, 4, 9, 16, 25, 36, 49, 64, 81]


/*2*/
var f = function (x) {
    return x * x;
};
var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
var result = [];
for (var i=0; i<arr.length; i++) {
    result.push(f(arr[i]));
}

诺,二者的原理其实并无两样,只不过map将函数进行了抽象化使得读者更加清晰的将结果视为:把f(x)作用在Array的每一个元素并把结果生成一个新的Array

划重点!!!!!
我等初学者可以勉强将map视为一个for循环,而其中的方法(函数)则代表了我们要对数组中每个元素进行处理所用到的方法(函数)

最后放一个将字符串转化为整数的小方法给大家看一下啦

var arr = ['1', '2', '3'];
var r;
r = arr.map(function(x){return parseInt(x);});

reduce

不知道在座的各位有没有学过数据结构,记不记得里边的广义表章节。

总之其中有一个广义表的存储方法名为头尾链表存储结构。叫的花哨其实没那么难懂。即使将广义表分为头尾两部分头部为值,尾部为指针指向后边的元素。后边的元素继续细分为头尾,以此类推
这里写图片描述

这里写图片描述

对没错就这么个玩意儿~为了省事我直接把PPT截了个图,大伙儿凑合着看啊

  • 那么这东西跟reduce有啥关系?
    • reduce规定必须接受两个参数。reduce()把结果继续和序列的下一个元素做累计计算
    • 效果就这样:[x1, x2, x3, x4].reduce(f) = f(f(f(x1, x2), x3), x4);—-像不像上面说到的广义表头尾链表存储结构倒过来(当然你得把最终的一个元素改成两个)?

有啥用?先来个简单的。对数组进行求和

var arr = [1, 3, 5, 7, 9];
arr.reduce(function (x, y) {
    return x + y;
});     // 25

看到没,效果是不是让你们想起了递归操作?没错。我只考虑前两个元素相加,后边的咱先放下不管。如此如此……就成了嘛~

不光如此,reduce还能将数组中的一组数转化为一个大整数

var arr = [1, 3, 5, 7, 9];
arr.reduce(function (x, y) {
    return x * 10 + y;
});         // 13579
  • 最后放一个不使用parseInt()利用map和reduce将字符串数组转化为整数的例子
    • Tips:想办法把一个字符串13579先变成Array——[1, 3, 5, 7, 9],再利用reduce()就可以写出一个把字符串转换为Number的函数。
'use strict';
function string2int(s) {

    //split()分割字符串返回的是一个数组;
    var arr = s.split('');
    return arr.map(function(x){
          //js的弱类型转换,‘-’会将字符串转变为数字,
          //x (乘) 1也是一个道理,但这样为何不直接return s (乘) 1呢;
          return x-0;
    }).reduce(function a(x,y){
       return x*10+y;
    });

}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值