最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 认识reduce的强大,实现一个简单reduce

    正文概述 掘金(虾仁炒猪心)   2020-11-29   570

    认识reduce

    Array.reduce(callback,starValue):接受两个参数:一个是对数组每个元素执行的回调方法,一个是初始值(可以是任意类型)。返回一个最后的累加值(与starValue同一类型)

    callback(accumulator,current,currentInedex,arr) 主要接收俩个参数,一个是当前的累加结果,一个是当前要累加的值

    使用reduce 实现数组求和

    var total = [1, 2, 3].reduce(function (accumulator, current) {
      return accumulator + current;
    }, 0);
    
    console.log(total) // 6
    

    使用reduce实现遍历数组中的对象,获取对象中符合条件的值并返回一个数组

    const arr = [
      {
        name: 'lgf',
        age: 22
      },
      {
        name: 'chm',
        age: 22
      },
      {
        name: 'lalal',
        age: 21
      }
    ]
    
    var newArr = arr.reduce(function (accumulator, current) {
      if (current.age === 22) {
        accumulator.push(current.name);
      }
      return accumulator;
    }, []);
    
    console.log(newArr) // ["lgf", "chm"]
    

    从数组生成 HTML 标签(返回字符串类型)

    var nameList = arr.reduce(function (accumulator, current) {
      if (current.age === 22) {
        accumulator += '<li>' + current.name + '</li>';
      }
      return accumulator;
    }, '');
    console.log(nameList) // <li>lgf</li><li>chm</li>
    
    

    累加一个对象

    var newArr = arr.reduce(function (accumulator, current) {
      if (current.age === 22) {
        const type = current.name
        accumulator[type]=current.name;
      }
      return accumulator;
    }, {});
    
    console.log(newArr) // {lgf: "lgf", chm: "chm"}
    

    最后 让我们来实现一个reduce方法

    Array.prototype.myReduce = function(fn, initialValue) {
      // 因为是数组调用 myReduce方法所以this指向当前数组
     // 初始化要返回累加值: 如果有传初始值则acc的初始值为initialValue,否则为数组的第一个个值
     let acc = initialValue || this[0]
     // 定义开始计算的索引:如果有传初始值则为0,否则为1
     const startIndex = initialValue ? 0 : 1
     // 遍历数组 执行传进来的函数(四个参数,前俩个是重点,1:当前累加总和,2:当前要累加的值,当前要累加值的索引,当前的数组)
     for (let i = startIndex; i < this.length; i++) {
      acc = fn(acc, this[i], i, this)
     }
     // 返回累加值
     return acc
    }
    

    加个参数判断

    Array.protopy.myReduce = function(fn,value){
        if(typeof fn !== 'function'){
             console.log('第一个参数必须为一个函数')
             return 
        }
        const acc =  value || this[0];
        const startIndex = value ? 0 : 1
        for(let i = startIndex; value.lenght,i++){
           acc = fn(acc,this[i],i,this)
        }
        return acc
    }
    

    起源地下载网 » 认识reduce的强大,实现一个简单reduce

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元