Underscore.js _.tap()函数什么是方法链?

pro*_*ons 4 javascript method-chaining chaining underscore.js

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]
Run Code Online (Sandbox Code Playgroud)

在这种情况下,方法链是什么?我一直认为方法链是链接方法的概念:object.foo().bar().baz().

我已经看过使用这种方法的例子:module.exports = _.tap {}, (connectors) ->,这也是"点击"对象文字的方法链吗?

mu *_*ort 10

精细手册:

链接
[...]
调用将导致所有将来的方法调用返回包装对象.完成计算后,使用value来检索最终值.

因此,在Underscore上下文链接与在其他地方链接相同,除了您在包装对象上链接Underscore方法.首先打电话_.chain来获取你的包装:

_(obj).chain()
Run Code Online (Sandbox Code Playgroud)

然后你在_.chain返回什么时调用Underscore方法,它们也将返回包装对象:

_(obj).chain()
      .filter(function(x) { ... })
      .map(function(x) { ... })
      ...
Run Code Online (Sandbox Code Playgroud)

最后你打电话_.value打开chaining-wrapper:

var result = _(obj).chain()
                   .filter(function(x) { ... })
                   .map(function(x) { ... })
                   ...
                   .value();
Run Code Online (Sandbox Code Playgroud)

回到_.tap.一切tap都是这样的:

_.tap = function(obj, interceptor) {
  interceptor(obj);
  return obj;
};
Run Code Online (Sandbox Code Playgroud)

所以它调用传递的函数,interceptor对迭代的值进行调用并返回正在迭代的内容而不对其做任何事情._.tap是相同的:

.map(function(x) { f(x); return x })
Run Code Online (Sandbox Code Playgroud)

但它使你的意图清晰.实际上,_.tap您可以查看通过方法链的数据,而无需更改该数据.

  • 说`_.chain(x)`或`_(x).chain()`给你包含在另一个对象里面的`x`支持Underscore函数.然后每个Underscore函数都会识别它正在处理一个包装对象并维护链中下一步的包装器. (3认同)

Bar*_*ney 8

我同意文档中的示例是愚蠢的,因为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 );
Run Code Online (Sandbox Code Playgroud)

这种情况确实有助于链接:上面的所有代码实际上都是创建并连续修改一个对象.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();
Run Code Online (Sandbox Code Playgroud)