Skip to content

配置

builder 打包器

  • 类型:BUILDER
  • 默认:BUILDER.WEBPACK
ts
export enum BUILDER {
  WEBPACK = 'webpack',
  RSPACK = 'rspack',
}

设置打包器。

antdTheme 主题配置

  • 类型:LessVars
ts
export interface LessVars {
  // 全局变量(直接定义的变量优先级高于变量文件)
  vars?: Record<string, string>
  // 全局变量文件
  file?: string
}

设置antd主题变量,可通过file属性直接设置配置文件路径,配置文件中需要默认导出一个配置对象。也可通过vars直接设置变量。

ts
antdTheme: {
  file: './src/theme/index.ts',
  vars: {
    colorPrimary: 'blue',
  },
}

lessVars 变量注入

  • 类型:LessVars
ts
export interface LessVars {
  // 全局变量(直接定义的变量优先级高于变量文件)
  vars?: Record<string, string>
  // 全局变量文件
  file?: string
}

注入less全局变量,可通过file属性直接设置配置文件路径,配置文件中需要默认导出一个配置对象。也可通过vars直接设置变量。

ts
antdTheme: {
  file: './src/theme/globalVars.ts',
  vars: {
    testColor: 'red',
  },
}

assets 资源处理

  • 类型:RzpackAssets
ts
export interface RzpackAssets {
  // jsx编译处理器
  jsxTools?: JSX_TOOLS
  // 是否使用cssScoped(类似Vue的scoped功能)
  cssScoped?: boolean
  // 是否压缩图片
  imageMini?: boolean
}

配置资源文件处理方式。

jsxTools

  • 类型:JSX_TOOLS
  • 默认:JSX_TOOLS.ESBUILD
ts
export enum JSX_TOOLS {
  ESBUILD = 'esbuild',
  SWC = 'swc',
}

jsx文件编译处理器。

注意:如果使用rspack打包,则jsxTools将默认为JSX_TOOLS.SWC且无法更改。

imageMini

  • 类型:boolean

是否压缩图片。

注意:在打包过程中压缩图片,会拖慢打包速度,建议手动压缩。

buildInfo 编译信息

  • 类型:boolean | BuildInfoWebpackPluginOptions

是否在控制台打印编译信息。更多配置参考:@renzp/build-info-webpack-plugin

cache 缓存

  • 类型:boolean
  • 默认 :true

是否使用持久化缓存。

注意:rspack目前不支持本地缓存,所以使用rspack打包时cache仅支持开发环境。

entry 入口

  • 类型:string\|string[]\|Record<string, string>
  • 默认 :./src/main.tsx

打包入口。

gzip 压缩

  • 类型:boolean

是否启用gzip。

html

  • 类型:HtmlWebpackPlugin.Options
  • 默认:index.html

htmlPlugin插件设置。配置参考: html-webpack-plugin

rspack参考: html-rspack-plugin

output 输出

  • 类型:Output
  • 默认 :dist

输出目录。配置参考:Output

publicPath

  • 类型:string
  • 默认 :public

静态资源目录。

server 开发服务

  • 类型:WebpackDevServerConfiguration

开发服务器配置,当开启可视化配置时此处配置的接口代理无效。配置参考:dev-server

rspack参考: dev-server

lazyCompilation 懒编译

  • 类型:LazyCompilationOptions

懒编译。配置参考:lazycompilation

moduleFederation 模块联邦

  • 类型:ModuleFederationPluginOptions
ts
export interface ModuleFederationShared {
  name: string
  requiredVersion: string
}

export interface ModuleFederationSharedAuto {
  deps: string[]
  depsPackagePath: string
}

export interface ModuleFederationPluginOptions {
  // 模块名称
  name: string
  // 模块导出名称
  filename?: string
  // 要共享的依赖
  shared?: ModuleFederationShared[] | ModuleFederationSharedAuto
  // 模块暴露的内容
  exposes?: Exposes
  // 模块引入的内容
  remotes?: Remotes
}

模块联邦。

rzpackChain 自定义配置

  • 类型:RzpackChain
ts
export type RzpackChain = (w: WebpackChain) => WebpackChain

使用webpackChain重写webpack/rspack配置。webpackChain用法参考:webpackChain

注意:因为webpackChain是webpack相关的包,rspack和webpack有细微差距,如果链式调用上属性报错,可直接使用.set设置。

proxyFile

  • 类型:string
  • 默认:./proxy.config.json

可视化配置的代理,仅在开启可视化配置时才生效。

reactRefresh React热更新

  • 类型:string

是否开启React代码热更新。

million React性能优化

  • 类型:boolean\|MillionOptions

是否使用Million.js。配置参考:Million.js

注意:million属性只用于生产环境。