用于按需引入组件库的代码和样式,能力等价于 babel-plugin-import。
它与 babel-plugin-import 的区别在于,source.transformImport
不与 Babel 耦合。Rsbuild 会自动识别当前使用的编译工具是 Babel、SWC 还是 Rspack,并添加相应的按需引入配置。
当使用上述 antd 默认配置:
源代码如下:
会被转换成:
你可以手动设置 transformImport: false
来关掉 transformImport 的默认行为。
比如,当你使用了 externals
来避免打包 antd 时,由于 transformImport
默认会转换 antd 的引用路径,导致匹配的路径发生了变化,因此 externals 无法正确生效,此时你可以设置关闭 transformImport
来避免该问题。
string
用于指定需要按需加载的模块名称。当 Rsbuild 遍历代码时,如果遇到了对应模块的 import 语句,则会对其进行转换。
string
'lib'
用于拼接转换后的路径,拼接规则为 ${libraryName}/${libraryDirectory}/${member}
,其中 member 为引入成员。
示例:
转换结果:
boolean
undefined
确定是否需要引入相关样式,若为 true
,则会引入路径 ${libraryName}/${libraryDirectory}/${member}/style
。
若为 false
或 undefined
则不会引入样式。
当配置为 true
时:
转换结果:
string
undefined
该配置用于拼接引入样式时的引入路径,若该配置被指定,则 style
配置项会被忽略。拼接引入路径为 ${libraryName}/${styleLibraryDirectory}/${member}
。
当配置为 styles
时:
转换结果:
boolean
true
是否需要将 camelCase 的引入转换成 kebab-case。
示例:
转换结果:
boolean
true
是否将导入语句转换成默认导入。
示例:
转换结果:
((member: string) => string | undefined) | string
undefined
自定义转换后的导入路径,输入是引入的成员,例如配置成 (member) => `my-lib/${member}`
,会将 import { foo } from 'bar'
转换成 import foo from 'my-lib/foo'
。
在使用 Rspack 构建时,不能使用函数配置,但可以使用 handlebars 模版字符串,对于上面的函数配置,在使用模版字符串时可以用以下模版代替 my-lib/{{ member }}
,也可以使用一些内置帮助方法,例如 my-lib/{{ kebabCase member }}
来转换成 kebab-case 格式,除了 kebabCase 以外还有 camelCase,snakeCase,upperCase,lowerCase 可以使用。
((member: string) => string | undefined) | string
undefined
自定义转换后的样式导入路径,输入是引入的成员,例如配置成 (member) => `my-lib/${member}`
,会将 import { foo } from 'bar'
转换成 import foo from 'my-lib/foo'
。
在使用 Rspack 构建时,不能使用函数配置,但可以使用 handlebars 模版字符串,对于上面的函数配置,在使用模版字符串时可以用以下模版代替 my-lib/{{ member }}
,也可以使用一些内置帮助方法,例如 my-lib/{{ kebabCase member }}
来转换成 kebab-case 格式,除了 kebabCase 以外还有 camelCase,snakeCase,upperCase,lowerCase 可以使用。