如何在 Visual Studio Code 中的事件上使用 JSDoc 自定义 EventEmitter?

2024-04-27

我一直致力于 Node.js 项目,只是注意到 Visual Studio Code 提供了有关基本 EventEmitter 对象的信息。所以我想也应该可以为自定义提供 JSDoc。

我已经尝试遵循 JSDochttp://usejsdoc.org/tags-event.html http://usejsdoc.org/tags-event.html文档,但似乎没有采纳。

我不知道这是否会影响它,但我正在使用 ES6 类,其中事件在其外部的函数中进行处理,但它位于同一脚本内。

这是测试代码。

// voice
if (voice) {
  try {
    /**
     * Voice event.
     *
     * @event TelegramBot#voice
     * @type {object}
     * @property {object} chat - [object Chat]
     * @property {number} date - Date when content was sent.
     * @property {object} from - [object User]
     * @property {number} message_id - Message id.
     * @property {string} caption - Caption added to message. Value is undefined if none is added.
     * @property {object} voice - [object Voice]
     */
    context.emit('voice', chat, date, from, message_id, caption, voice)
  } catch (error) {
    context.emit('error', error)
  }
}

我在尝试做同样的事情时发现了这个问题,所以我继续搜索并找到了一个可能的解决方案,通过覆盖addListener方法,并记录它们。

我成功地使其适用于 NodeJS 和浏览器 JS。

VSCode 中的结果

Typedef

首先,使用您的事件名称创建 typedef :

/**
 * @typedef {["someEvent" | "someOtherEvent", ...any[]]} eventsDef
 */

我正在使用扩展语法,因为我不知道用户将传递多少参数给该方法。

执行

对于 NodeJS:

该类需要重写on and addListener方法,记录参数,然后简单地调用父级自己的方法:

class Test extends EventEmitter {

  /**
   * @param {eventsDef} args
   */
  addListener(...args) {
    super.addListener(...args);
  }

  /**
   * @param {eventsDef} args
   */
  on(...args) {
    super.on(...args);
  }

  fireEvent() {
    this.emit("someEvent", "someValue");
  }
}

然后你可以像这样使用这个类:

const t = new Test();

t.on("someEvent", (val) => console.log(val));

t.fireEvent(); // Outputs "someValue"

对于浏览器:

班级需要扩展EventTarget并覆盖addEventListener method.

这是片段:

class Test extends EventTarget {
  /**
   * @param {["someEvent" | "someOtherEvent", ...any[]]} args
   */
  addEventListener(...args) {
    super.addEventListener(...args);
  }
  
  fireEvent() {
    this.dispatchEvent(new CustomEvent("someEvent", {detail: "someValue"}))
  }
}

const t = new Test();

t.addEventListener("someEvent", val => console.log(val.detail));


document.querySelector("button").addEventListener("click", () => {
  t.fireEvent();
})
<button>Fire event</button>
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

如何在 Visual Studio Code 中的事件上使用 JSDoc 自定义 EventEmitter? 的相关文章