无法在不提供文件扩展名的情况下导入 TypeScript 模块

Posted

技术标签:

【中文标题】无法在不提供文件扩展名的情况下导入 TypeScript 模块【英文标题】:Can't import TypeScript modules without providing the file extension 【发布时间】:2016-07-30 08:50:06 【问题描述】:

我是 TypeScript 的新手,我希望我应该能够导入我的 TS 文件,而无需指定它们是 TS 文件。

我必须这样做

import sealed from "./decorators/decorators.ts";

而不是我想要的正确方法是

import sealed from "./decorators/decorators";

这会导致错误,表明它只是在寻找以 .js 或 .jsx 结尾的文件

我的 tsconfig.json 看起来像这样


"compileOnSave": true,
"compilerOptions": 
    "module": "commonjs",
    "moduleResolution": "node",
    "jsx": "react",
    "allowJs": true,
    "target": "es6",
    "removeComments": true,
    "experimentalDecorators": true,
    "emitDecoratorMetadata": true
,
"exclude": [
    "node_modules",
    "typings/browser",
    "typings/browser.d.ts"
]

【问题讨论】:

我看到您将模块编译成 commonjs 模块。你用什么来加载它们?网络包?还是这是一个节点应用程序? 我正在使用 Webpack 【参考方案1】:

如果您使用的是 webpack,请尝试将其添加到您的 webpack.config.js 文件中:

resolve: 
  extensions: ['', '.js', '.jsx', '.ts', '.tsx']
,

【讨论】:

天啊,就是这样。谢谢!【参考方案2】:

thitemple 的回答对我有用,但我不得不从数组中删除 '',因为它阻止了 webpack 的启动。

resolve: 
  extensions: ['.js', '.jsx', '.ts', '.tsx']
,

【讨论】:

以上是关于无法在不提供文件扩展名的情况下导入 TypeScript 模块的主要内容,如果未能解决你的问题,请参考以下文章

在不导入自己的情况下播放系统声音

如何在不检查路径扩展名的情况下检查文件是不是为图像文件?

PHP - 在不知道扩展名的情况下检查文件是不是存在

如何在不使用任何付费工具的情况下将 dbf 文件导入 mysql?

webpack 可以在不需要或导入的情况下捆绑 js 文件吗? Q2:为啥需要图表?

TypeScript:我可以在不编写 index.ts 文件的情况下导入文件夹吗?