javascript - TypeScript 定义文件必须位于包的根目录吗?
问题描述
假设我有一个包含两个文件的 TypeScript 包,这两个文件(无论出于何种原因)至少在技术上彼此无关,而是独立的。此外,没有index.ts
文件或类似的东西可以作为统一的入口点,而是这个包中的文件是单独导入的。
所以,我们有一个这样的文件夹结构:
src/
a.ts
b.ts
dist/
a.js
a.d.ts
b.js
b.d.ts
package.json
由于显而易见的原因,我不能将单个.d.ts
文件放入types
. package.json
现在,如果我导入这样的文件:
import a from 'somepackage/a';
IDE 是否检测到正确的.d.ts
文件,还是我需要以不同的方式做任何事情?这是官方的方式吗,还是我需要注意什么,或者我必须做些什么才能使事情正常进行?
解决方案
如果您将类型与您的包捆绑在一起,您应该使用“types”属性在您的 package.json 文件中引用您的类型定义:
{
"name": "whatever-package",
...
"main": "./dist/main.js"
"types": "./dist/typings.d.ts",
...
}
不幸的是,“类型”仅支持一个字符串值,因此您只能传递一个应该包含捆绑类型定义的路径。这是因为它与您的主条目文件对应(也仅支持 1 个路径)。
编辑:要解决此限制,您的类型文件(以及您的主条目文件)可能只是一个导出具体定义的包装器,如下所示:
打字.d.ts
export { SomeObject } from './path/SomeObject';
export { SomeOtherObject } from './some/other/path/SomeOtherObject';
在这种情况下 SomeObject.d.ts 和 SomeOtherObject.d.ts 应该存在于相应的路径上。
推荐阅读
- tensorflow - 无法将生成器从 estimator.predict 转换为列表
- javascript - Javascript:无法读取未定义的属性“长度”
- python-3.x - 在 P4 中,我如何使用命令检查提交到一个分支的更改是否也提交到另一个分支
- r - 我无法在 R 中安装包 tcltk
- java - 如何在不出现 StackOverflowError 的情况下删除静态?
- javascript - 使用 javascript 使用 iframe 时如何打开新选项卡
- docker - 如何使用 docker 容器创建 vsftpd 服务器?
- javascript - 需要帮助尝试在本机反应中刷新我的令牌
- excel - Excel:创建宏以将活动选择复制并粘贴到另一个工作表中
- vue.js - Vuejs 性能调优 - 监控我的组件何时重新渲染