下划线's每次检查回调的{}返回
underscore's each checking for {} return of callback
我正在研究UndercoreJS如何实现他们的each
/forEach
//somewhere up top:
var breaker = {};
//then the each function
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 (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;
}
}
}
};
//iterator = callback
//context = optional third parameter of each to provide context in the callback
//obj = the list
//key = key of the object (i for index when an array)
基本上,它为对象/数组中的每个项执行回调。但这让我很困惑
if (iterator.call(context, obj[key], key, obj) === breaker) return;
据我所知,如果回调返回一个对象,循环就会中断,但是为什么它与breaker
相比,后者是下划线模块中的内部对象。它不是一直计算为false
吗?因为即使回调确实返回了一个对象,它也总是false
,因为它不是同一个对象(因此循环从不中断)。这背后的原因是什么?
他们在内部使用each
,例如some
。由于some
确实短路,他们可以使用"secret"对象让each
在那里中断,而不会向普通用户公开此功能。它们不公开break功能,因为本机函数也不这样做(所以它们的填充程序尽可能像本机一样)。如果他们这样做了,中断功能只有在本机函数无效的情况下才可用,这并没有特别的帮助。
相关文章:
- 如何使for循环等待回调返回值
- node.js mongojs findOne回调返回错误为null
- 在回调返回错误中带有点的 JSONP
- 从嵌套在函数中的Node.js回调返回对象
- 回调返回响应,但当在API中发送时,响应在节点JS中显示为空白
- 挂起的回调:在每次回调返回之前返回响应
- 当查询返回对象时,Express Mongo回调返回undefined
- 而循环和回调返回不同的结果
- 从Meteor.method中的回调返回值
- jquery getjson 函数:回调返回错误的字符串
- 承诺回调返回承诺
- AJAX 回调返回 0
- 通过回调返回 AJAX
- Javascript 从多个回调返回值
- 从 JavaScript 回调返回一个值
- 从回调返回值
- grunt-从回调返回解析的数据
- Firebase-回调返回[object object]
- Javascript回调返回值
- 当一个promise的resolve回调返回另一个promise时,它是如何工作的