0

重複の可能性:
アンダースコアがコールバックの {} 戻り値をチェックするたびに

アンダースコアのソースと Foreach メソッドの実装を調べていました。以下の方法で1つだけ質問があります。

var breaker = {};

var each = _.each = _.forEach = function(obj, iterator, context) {
   if (obj == null) return;
   if (nativeForEach && obj.forEach === nativeForEach) {
     obj.forEach(iterator, context);
   } else if (obj.length === +obj.length) {
     for (var i = 0, l = obj.length; i < l; i++) {
        if (i in obj && iterator.call(context, obj[i], i, obj) === breaker) return;
     }
   } else {
      for (var key in obj) {
        if (_.has(obj, key)) {
          if (iterator.call(context, obj[key], key, obj) === breaker) return;
        }
      }
   }
};

次の行に苦労していますか?呼び出されたイテレータが空のオブジェクトかどうかを確認するのはなぜですか? イテレータから空のオブジェクトを返すのはなぜですか?

if (iterator.call(context, obj[key], key, obj) === breaker) return;
4

0 に答える 0