gpt4 book ai didi

javascript - 如何在 JSDoc 中注释具有可变参数数量的 Function 类型的对象?

转载 作者:行者123 更新时间:2023-12-04 07:34:21 26 4
gpt4 key购买 nike

我得到了以下代码:

/**
* @type {function(boolean, string, ...*):void}
*/
exports.warn = createMacro(macro)

warn 是一个函数,其签名为 (arg1, arg2, ...arg3)。当我尝试在其他地方使用此方法时,WebStorm 和 VSCode 提示说,第三个参数是必需的,而不是可选的

code underlined in IDE

根据此注释生成 .d.ts 文件时,签名是正确的:arg0: boolean, arg1: string, ...args: any[]我如何修改注解,这样 IDE 就不会提示缺少参数?

最佳答案

我找不到通过使用 @type 的内联函数定义来解决您的问题的方法。但是,您可以考虑一些具有一些缺点的替代方案。

第一种方式使用 JSDoc 语法并且应该与读取它的任何工具兼容。我首先声明一个@callback 函数类型,然后将变量的类型设置为它。通过将最后一个参数名称括在方括号中,该参数变为可选参数,这应该会清除您的错误。

/**
* @callback WarnFunc
* @param {boolean} arg1
* @param {string} arg2
* @param {...*} [restParam]
* @returns void
*/
/** @type WarnFunc*/
exports.warn = createMacro(macro);

上面的问题是它比你以前的要冗长得多。 TypeScript 支持在 TypeScript 语法和 JSDoc 语法中定义的类型参数。因此,如果维护 JSDoc 的语法不是优先事项,则以下方法应该可行并且更简洁:

/**
* @type {(arg1: boolean, arg2: string, ...restArgs: string[]) => void}
*/
exports.warn = createMacro(macro);

当我这样做时,我没有收到任何错误,但是 restArgs 参数也没有显示为可选参数。因此,如果您仍然有问题,可以显式地将其余参数设为可选。虽然它不是有效的 TypeScript 语法,但我尝试时它似乎有效。

@type {(arg1: boolean, arg2: string, ...restArgs?: string[]) => void}

关于javascript - 如何在 JSDoc 中注释具有可变参数数量的 Function 类型的对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67806716/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com