如何在打字稿中将两个参数传递给函数或无参数?

时间:2021-05-26 09:18:11

标签: typescript parameters parameter-passing

我想改进一个只返回状态的函数。除了记录器和用它记录的消息外,它不接受任何其他参数。

export function status(logger: Logger, reason: string) {
  logger.info(reason);
  return {
    result: 'ok'
  };
}

但是我想让参数可选,所以如果我不想记录任何东西,我不需要传递任何东西。所以我改成这样:

export function status(logger?: Logger, reason?: string) {
  reason && logger?.info(reason);
  return {
    result: 'ok'
  };
}

但是我仍然可以提供记录器但没有提供原因,我不喜欢那样。我希望这个函数接受两个参数或不接受参数。所以我尝试了这样的事情:

export function status(param: {logger: Logger, reason: string} | {} = {}) {
  param?.logger.info(reason);
  return {
    result: 'ok'
  };
}

但是现在我收到 TS2339: Property 'logger' does not exist on type '{} | { logger: Logger; reason: string; }'.   Property 'logger' does not exist on type '{}'. 并且我不知道如何正确执行此操作。我想学习 - 你能解释一下这是如何实现的吗?

1 个答案:

答案 0 :(得分:1)

编辑:您没有提供 Logger 类型的外观。但是看到您的代码,我认为它必须与此类似:

type Logger = { info: (someInfo: string) => void }

定义状态函数接收的参数类型:

type paramsStatus = {
  logger: { info: (someInfo: string) => void },
  reason: string,
}

您使用 ?操作员。由于 logger 和 reason 是强制性的(参见上面的类型),它们都必须传递给状态函数。两种方法都对,两种方法都对。

export function status(params?: paramsStatus) {
  params && params.logger.info(params.reason); //If params exist, then log the info
  return {
    result: 'ok',
  };
}