Underscore.js文档解释了该_.tap()
功能"点击"到方法链中.http://underscorejs.org/#tap
我跟随他们的例子有困难:
_.chain([1,2,3,200]) .filter(function(num) { return num % 2 == 0; }) .tap(alert) .map(function(num) { return num * num }) .value(); => // [2, 200] (alerted) => [4, 40000]
在这种情况下,方法链是什么?我一直认为方法链是链接方法的概念:object.foo().bar().baz()
.
我已经看过使用这种方法的例子:module.exports = _.tap {}, (connectors) ->
,这也是"点击"对象文字的方法链吗?
我同意文档中的示例是愚蠢的,因为alert
迭代对象永远不是你想要在实际情况下做的事情(除非你正在调试并想知道2个链式方法之间的对象状态 - 但在这种情况下它可能只是提醒[object Object]
; console.log
会更合适,但不会按预期工作[但我离题]).以下是非链接工作流程的示例:
var x = { a: 1, b: 2, c: 3 }; x = _.filter( x, function( value ){ return ( value % 2 === 0 ); } ); x.length = _.size( x ); x = _.pairs( x );
这种情况确实有助于链接:上面的所有代码实际上都是创建并连续修改一个对象.Chaining清楚地说明了这一点,并阻止你不断写作.唯一的问题是我声明的行length
- 它不能完全适合链,因为它是唯一的声明,它不是简单地在对象上运行下划线方法并将结果分配回该对象.而这就是tap
进来的地方:你想要做一些不容易在链条内链接的东西.以下是他链接工作流程的方式:
var x = _ .chain( { a: 1, b: 2, c: 3 } ) .filter( function( value ){ return ( value % 2 === 0 ); } ) .tap( function( x ){ x.length = _.size( x ); } ) .pairs() .value();
从精细手册:
链接
[...]
调用链将导致所有将来的方法调用返回包装对象.完成计算后,使用value来检索最终值.
因此,在Underscore上下文链接与在其他地方链接相同,除了您在包装对象上链接Underscore方法.首先打电话_.chain
来获取你的包装:
_(obj).chain()
然后你在_.chain
返回什么时调用Underscore方法,它们也将返回包装对象:
_(obj).chain() .filter(function(x) { ... }) .map(function(x) { ... }) ...
最后你打电话_.value
打开chaining-wrapper:
var result = _(obj).chain() .filter(function(x) { ... }) .map(function(x) { ... }) ... .value();
回到_.tap
.一切tap
都是这样的:
_.tap = function(obj, interceptor) { interceptor(obj); return obj; };
所以它调用传递的函数,interceptor
对迭代的值进行调用并返回正在迭代的内容而不对其做任何事情._.tap
是相同的:
.map(function(x) { f(x); return x })
但它使你的意图清晰.实际上,_.tap
您可以查看通过方法链的数据,而无需更改该数据.