路径别名(alias)允许开发者为模块定义别名,以便于在代码中更方便的引用它们。当你想要使用一个简短、易于记忆的名称来代替冗长复杂的路径时,这将非常有用。
例如,假如你在项目中经常引用 src/common/request.ts
模块,你可以为它定义一个别名 @request
,然后在代码中通过 import request from '@request'
来引用它,而不需要每次都写出完整的相对路径。同时,这也允许你将模块移动到不同的位置,而不需要更新代码中的所有 import 语法。
在 Rsbuild 中,你有两种方式可以设置路径别名:
tsconfig.json
中的 paths
配置。tsconfig.json
的 paths
配置你可以通过 tsconfig.json
中的 paths
来配置别名,这是我们在 TypeScript 项目中推荐使用的方式,因为它可以解决路径别名的 TS 类型问题。
比如:
以上配置完成后,如果你在代码中引用 @common/Foo.tsx
, 则会映射到 <project>/src/common/Foo.tsx
路径上。
你可以阅读 TypeScript - paths 文档来了解更多用法。
resolve.alias
配置Rsbuild 提供了 resolve.alias 配置项,对应 Rspack 原生的 resolve.alias 配置,你可以通过对象或者函数的方式来配置这个选项。
由于 tsconfig.json
的 paths
配置是写在静态 JSON 文件里的,因此它不具备动态性。
而 resolve.alias
则可以弥补这一不足,你可以通过 JavaScript 代码来动态设置 resolve.alias
(比如基于环境变量来设置)。
你可以通过对象的方式来配置 resolve.alias
,其中的相对路径会被自动补全为绝对路径。
比如:
以上配置完成后,如果你在代码中引用 @common/Foo.tsx
, 则会映射到 <project>/src/common/Foo.tsx
路径上。
你也可以将 resolve.alias
配置为一个函数,拿到内置的 alias
对象,对其进行修改。
比如:
tsconfig.json
的 paths
配置的优先级高于 resolve.alias
,当一个路径同时匹配到这两者定义的规则时,会优先使用 tsconfig.json
的 paths
定义的值。
你可以通过 resolve.aliasStrategy 来调整这两个选项的优先级。