node-mysql 文档中的奇怪用法

Strange usage in node-mysql documantation

在阅读 node-mysql 文档时,我看到了下面粘贴的用法

var query = connection.query('SELECT * FROM posts');
query
  .on('error', function(err) {
    // Handle error, an 'end' event will be emitted after this as well
  })
  .on('fields', function(fields) {
    // the field packets for the rows to follow
  })
  .on('result', function(row) {
    // Pausing the connnection is useful if your processing involves I/O
    connection.pause();

    processRow(row, function() {
      connection.resume();
    });
  })
  .on('end', function() {
    // all rows have been received
  });

我想知道他们是如何使用这些事件的,这些事件可以与名称一起使用 例如,用户将查询命名为 query,当我创建自定义事件时,我首先将它们命名为 var foo=new events.EventEmitter,然后在整个页面中我必须将其用作 foo.on("someEvent") 但是在这里,他们以某种方式将用户创建的 var 绑定为示例代码中的事件名称用户将 mysql 查询命名为 query,并且事件发射器以某种方式具有相同的名称

第二个问题是如何在使用

时链接事件
.on("event").on("anotherEvent")

这个问题听起来很奇怪,但我真的很想知道它是如何工作的,它会彻底改变我的代码设计

query 只是 node-mysql 库中 Query 实例的变量名称。您可以访问对象导出的所有函数。

on继承自node.js核心中的EventEmitter。关键是调用 on returns "itself" 即 this:

Returns emitter, so calls can be chained.

这允许您将调用链接到 on