javascript - underscore的reduce和reduceRight为什么不使用native function ?
PHP中文网
PHP中文网 2017-04-11 11:08:58
[JavaScript讨论组]

在读underscore的源码,有一个疑问,为什么不优先选择原生的reducereduceRight

源码中,比如 _.keys,都是先探测是否支持Object.keys的。

 // Create a reducing function iterating left or right.
  // ? why dont use native reduce
  var createReduce = function(dir) {
    // Wrap code that reassigns argument variables in a separate function than
    // the one that accesses `arguments.length` to avoid a perf hit. (#1991)
    var reducer = function(obj, iteratee, memo, initial) {
      var keys = !isArrayLike(obj) && _.keys(obj),
          length = (keys || obj).length,
          index = dir > 0 ? 0 : length - 1;
      if (!initial) {
        memo = obj[keys ? keys[index] : index];
        index += dir;
      }
      for (; index >= 0 && index < length; index += dir) {
        var currentKey = keys ? keys[index] : index;
        memo = iteratee(memo, obj[currentKey], currentKey, obj);
      }
      return memo;
    };

    return function(obj, iteratee, memo, context) {
      var initial = arguments.length >= 3;
      return reducer(obj, optimizeCb(iteratee, context, 4), memo, initial);
    };
  };
// **Reduce** builds up a single result from a list of values, aka `inject`,
// or `foldl`.
_.reduce = _.foldl = _.inject = createReduce(1);

// The right-associative version of reduce, also known as `foldr`.
_.reduceRight = _.foldr = createReduce(-1);
PHP中文网
PHP中文网

认证高级PHP讲师

全部回复(1)
伊谢尔伦

原生的reduce方法是Array的原型对象中带的方式,对于类数组对象不适用
例如

var arraylike={length:2,"1":1,"0":2};
//会保存
arraylike.reduce(function(previousValue, currentValue, currentIndex, array) {
  return previousValue + currentValue;
});//Uncaught TypeError: arraylike.reduce is not a function

需要通过如下才可以:

Array.prototype.reduce.call(arraylike,function(previousValue, currentValue, currentIndex, array) {
  return previousValue + currentValue;
});

同样不支持对普通对象的属性的遍历reduce操作

var obj={name:'A',age:30,level:10};
var keyArray=Object.keys(obj);
keyArray.reduce(function(previousValue, currentValue, currentIndex, array) {
  return previousValue +','+currentValue;
});

而underscore提供对类数据对象和普通对象属性的遍历reduce操作

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号