使用可选的第一个参数记录JavaScript

时间:2017-12-20 01:43:17

标签: javascript webstorm jsdoc

我正在尝试记录其中一个烦人的函数,它们在JavaScript中有一个可选的 first 参数。

类似.use()

中的express功能
function use(path, callback) // path is optional

我正在努力找到有用的东西,理想情况下并不是非常难看。

我对实际代码签名的偏好是:

function use(...args) {
  const [callback, path] = args.reverse();
}

在这种情况下,我没有两个参数,所以如果我尝试使用两个@param行,我会在JSDoc块中大喊:

/**
 * @param {String=} path
 * @param {Function} callback
 */
function use(...args) // mismatched parameters

如果我按预期使用参数并使用不同的模式来放置参数,我会(由WebStorm)大吼大叫,因为callback不是String

/**
 * @param {String=} path
 * @param {Function} callback
 */
function use(path, callback) {
  if (typeof path == 'function') {
    callback = path; // yelled at because callback can't be a string
    path = undefined;
  }
}

我在谷歌上搜索了很多旧的东西,不同的人在讨论这个问题,但没有明确的答案。由于帖子较旧且发生了很多,我想重新问:有没有办法记录这一切,所以一切都很开心(至少在WebStorm中),或者是否有一些新的ES#语法允许可选的第一个参数(这可以产生适当的自动完成)?

1 个答案:

答案 0 :(得分:1)

@param {(String=|Function=)} path

可能就是你要找的东西。