繁体   English   中英

TypeScript 用于破坏 function 有效负载的类型声明 (d.ts)

[英]TypeScript type declaration (d.ts) for destructing function payload

使用网络风暴。 TypeScript v4.6.2

我在常规 JavaScript 文件index.js中有一个 function 。 在它旁边我有类型声明文件index.d.ts 此类型声明文件的唯一目的是获得自动完成建议。

在 JS 文件中我有一个 function:

module.exports.myFunction = async ({foo}) => {
  foo. // <-- expecting to get suggestion "bar"
}

TypeScript 类型声明文件需要如何查找以为此foo内部的bar提供自动完成功能?

尝试这样做:

interface payload {
  foo: {
    bar: string;
  };
}

declare function myFunction(object: payload): any;

export default myFunction;

得到这样的“建议”:

在此处输入图像描述

如果我从任何其他位置需要这个myFunction ,那么我确实会按预期获得建议,但我想在myFunction本身内部获得该建议:

在此处输入图像描述

文件结构:

在此处输入图像描述

TypeScript 不会以神奇的方式工作,在您的情况下,使其工作的最佳方法是导出界面并将其导入 JSDoc 注释中,以便在 function 键入中使用。 所以你的文件应该是这样的:

// index.d.ts file

export interface Payload { // Interface name should be capitalized
  foo: {
    bar: string;
  };
}
// index.js file

/**
 * @typedef {import('.').Payload} Payload
 */

/**
 * @param {Payload} param
 */
const myFunction = async ({ foo }) => {
  foo. // <-- You will get here the suggestion for "bar"
};

module.exports = { myFunction };

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM