相对路径和非相对路径:
1. 相对路径:
相对路径是相对于当前文件的路径,以 ./ 或 ../ 开头。
// 相对路径导入
import { something } from './path/to/module';
2. 非相对路径:
非相对路径是不以 ./ 或 ../ 开头的路径,例如 Node.js 模块的解析方式。
// 非相对路径导入
import { something } from 'module';
模块解析策略:
TypeScript 提供了不同的模块解析策略,可以在 tsconfig.json 文件中配置。以下是一些常见的模块解析策略:
1. 经典模块解析(Classic Module Resolution):
默认使用的是经典模块解析,适用于 Node.js 项目。在 tsconfig.json 中,设置 "moduleResolution": "node"。
// tsconfig.json
{
"compilerOptions": {
"moduleResolution": "node",
// ...
}
}
2. 相对模块解析(Relative Module Resolution):
在 tsconfig.json 中,设置 "moduleResolution": "classic"。
// tsconfig.json
{
"compilerOptions": {
"moduleResolution": "classic",
// ...
}
}
3. 自定义模块解析路径:
可以在 tsconfig.json 中使用 "baseUrl" 和 "paths" 来设置自定义的模块解析路径。
// tsconfig.json
{
"compilerOptions": {
"baseUrl": "./src",
"paths": {
"lib/*": ["lib/*"]
},
// ...
}
}
在这个例子中,如果有一个导入语句 import { something } from 'lib/module';,TypeScript 将会在 ./src/lib/module.ts 中寻找模块。
混合模块解析:
在一些复杂的项目中,可以使用混合的模块解析策略。这允许将相对路径和非相对路径结合使用。
// tsconfig.json
{
"compilerOptions": {
"moduleResolution": "node",
"baseUrl": "./src",
"paths": {
"lib/*": ["lib/*"]
},
// ...
}
}
在这个例子中,TypeScript 将使用 Node.js 的模块解析策略,并在需要时回退到相对路径解析。
使用 tsc 命令的 --traceResolution 选项:
通过在 tsc 命令中使用 --traceResolution 选项,可以输出详细的模块解析信息,帮助调试模块解析问题。
tsc --traceResolution
以上是 TypeScript 中模块解析的一些基本概念和配置。正确配置模块解析对于项目的组织和维护非常重要。根据项目的需要选择合适的解析策略,并通过 tsconfig.json 进行配置。
转载请注明出处:http://www.pingtaimeng.com/article/detail/4708/TypeScript