编译配置详情
#
designWidthdesignWidth
用来设置设计稿尺寸,关于这一部分的配置说明请见设计稿及尺寸单位这一章节。
#
sourceRootsourceRoot
用来设置源码存放目录,通过 Taro 开发工具初始化后的项目源码目录都是 src
,你可以通过修改这一配置来重新指定源码目录。
#
outputRootoutputRoot
用来设置代码编译后的生产目录,通过 Taro 开发工具初始化后的生产目录都是 dist
,你可以通过修改这一配置来重新指定生产目录。
#
plugins自 2.2 开始,Taro 引入了插件化机制,允许开发者通过编写插件的方式来为 Taro 拓展更多功能或者为自身业务定制个性化功能
plugins
用来配置 Taro 插件。
plugins
字段取值为一个数组,配置方式如下:
#
presets如果你有一系列插件需要配置,而他们通常是组合起来完成特定的事儿,那你可以通过插件集 presets
来进行配置。
配置编译配置中的 presets
字段,如下。
#
babel用来配置 babel
,默认配置如下,可以自行添加自己需要的额外的 presets
及 plugins
。
#
uglify自 2.2.8 开始,需要安装
@tarojs/plugin-uglify
插件才能使用此配置
用来配置 UgligyJS
工具,设置打包过程中的 JS 代码压缩。可以通过 uglify.enable
来设置是否开启压缩,若设置开启,则可以通过 uglify.config
来设置 UgligyJS
的配置项,具体配置方式如下:
#
terser自 2.2.8 开始,需要安装
@tarojs/plugin-terser
插件才能使用此配置
用来配置 terser
工具,设置打包过程中的 JS 代码压缩。可以通过 terser.enable
来设置是否开启压缩,若设置开启,则可以通过 terser.config
来设置 terser
的配置项,具体配置方式如下:
#
csso用来配置 csso
工具,设置打包过程中的 CSS 代码压缩。可以通过 csso.enable
来设置是否开启压缩,若设置开启,则可以通过 csso.config
来设置 csso
的配置项,具体配置方式如下:
#
sass自 2.2.8 开始,需要安装
@tarojs/plugin-sass
插件才能使用此配置
用来配置 sass
工具,设置打包过程中的 SCSS 代码编译。
具体配置可以参考node-sass
当需要全局注入scss文件时,可以添加三个额外参数:resource
、 projectDirectory
(v1.2.25开始支持)、data
(v1.3.0开始支持),具体配置方式如下:
#
单文件路径形式当只有 resource
字段时,可以传入 scss 文件的绝对路径。
#
多文件路径形式此外,当只有 resource
字段时,也可以传入一个路径数组。
#
指定项目根目录路径形式你可以额外配置 projectDirectory
字段,这样你就可以在 resource
里写相对路径了。
#
传入 scss 变量字符串- resource: 如果要引入多个文件,支持数组形式传入
- projectDirectory: 项目根目录的绝对地址(若为小程序云开发模板,则应该是client目录)
- data: 全局 scss 变量,若 data 与 resource 中设置了同样的变量,则 data 的优先级高于 resource
#
env用来设置一些环境变量如 process.env.NODE_ENV
,例如我们想设置区分预览、打包来做些不同的操作,可以如下配置:
在 config/dev.js
中:
在 config/prod.js
中:
这样就能在代码中通过 process.env.NODE_ENV === 'development'
来判断环境。
注意 Taro 在小程序中只暴露 TARO_ENV
以及在 config/*
下配置文件中 env
字段定义的环境变量,若需要通过 npm script
的方式通过命令行设置环境变量,可在 config/*
下配置文件中获取到对应的值,然后设置到配置文件中:
在 config/dev.js
中:
在yarn
/npm
中:
#
defineConstants用来配置一些全局变量供代码中进行使用,配置方式与 Webpack DefinePlugin 类似,例如:
#
alias
1.2.0
开始支持。
用来配置目录别名,从而方便书写代码引用路径。例如,使用相对路径书写文件引用如下:
为了避免书写多级相对路径,我们可以如下配置 alias
:
通过上述配置,可以将 src/components
和 src/utils
目录配置成别名,将根目录下的 package.json
和 project.config.json
文件配置成别名,则代码中的引用改写如下:
为了让编辑器(VS Code)不报错,并继续使用自动路径补全的功能,需要在项目根目录下的 jsconfig.json
或者 tsconfig.json
中配置 paths
让编辑器认得我们的别名,形式如下:
建议别名使用 @/
开头而非仅用 @
开头,因为有小概率会与某些 scoped
形式的 npm
包(行如:@tarojs/taro, @babel/core)产生命名冲突。
#
copy文件 copy 配置,包含两个配置项 patterns
和 options
。
#
copy.patterns用来指定需要拷贝的文件或者目录,数组类型,每一项都必须包含 from
、to
的配置,分别代表来源和需要拷贝到的目录,同时可以设置 ignore
配置来指定需要忽略的文件, ignore
是指定的 glob 类型字符串,或者 glob 字符串数组。
值得注意的是,目前 from
必须指定存在的文件或者目录,暂不支持 glob 格式, from
和 to
直接置顶项目根目录下的文件目录,建议 from
以 src
目录开头,to
以 dist
目录开头。
一般有如下的使用形式:
#
copy.options拷贝配置,目前可以指定全局的 ignore:
#
mini专属于小程序的配置。
#
mini.compile小程序编译过程的相关配置。
#
mini.compile.exclude配置小程序编译过程中排除不需要经过 Taro 编译的文件,数组类型,数组里面可以包含具体文件路径,也可以是判断函数,同 Rule.exclude
例如,想要排除某个文件,可以如下配置要排除的文件具体路径:
也可以配置判断函数,如下
#
mini.compile.include配置额外需要经过 Taro 编译的文件,例如 Taro 默认不编译 node_modules
包中文件,可以通过这个配置让 Taro 编译 node_modules
包中文件,使用方式与 mini.compile.exclude
一致,同 Rule.include。
#
mini.webpackChain自定义 Webpack 配置,接受函数形式的配置。
这个函数会收到三个参数,第一个参数是 webpackChain 对象,可参考 webpack-chain 的 api 进行修改;第二个参数是 webpack
实例;第三个参数 PARSE_AST_TYPE
是小程序编译时的文件类型集合。例如:
注意:第三个参数的取值如下
#
mini.commonChunks
type commonChunks = string[] | ((commonChunks: string[]) => string[])
配置打包时抽离的公共文件
支持两种配置方式,其一是字符串数组,给定抽离公共文件名,在 Taro 编译中,如果是普通编译,则 commonChunks 默认值为 ['runtime', 'vendors', 'taro', 'common']
,如果是编译为微信小程序插件,则 commonChunks 默认值为 ['plugin/runtime', 'plugin/vendors', 'plugin/taro', 'plugin/common']
,普通编译时默认配置
这几个公共文件分别表示:
runtime
: webpack 运行时入口vendors
: node_modules 中文件抽离taro
: node_modules 中 Taro 相关依赖抽离common
: 项目中业务代码公共文件抽离
其二是函数,通过对入参的默认公共文件数组进行操作,返回新的数组来进行配置,如下
commonChunks
的配置值主要依据 webpack 配置 optimization.runtimeChunk
和 optimization.splitChunks
,Taro 中默认的配置分别为
如果有自行拆分公共文件的需求,请先通过 webpackChain
配置覆盖 optimization.runtimeChunk
与 optimization.splitChunks
配置,再通过 commonChunks
配置指定的公共入口文件。
#
mini.addChunkPages2.0.5 开始支持
type addChunkPages = ((pages: Map<string, string[]>, pagesNames?: string[]) => void)
在某些情况下,我们可能需要为某些页面单独指定需要引用的公共文件,例如,使用小程序分包的时候,为了减少主包大小,分包的页面希望引入自己的公共文件,而不希望直接放在主包内,那么我们首先可以通过配置 mini.webpackChain
来单独抽离分包的公共文件,然后通过 mini.addChunkPages
为分包页面配置引入子包公共文件,其使用方式如下:
mini.addChunkPages
配置为一个函数,接受两个参数
pages
参数为 Map 类型,用于为页面添加公共文件pagesNames
参数为当前应用的所有页面标识列表,可以通过打印的方式进行查看页面的标识
例如,为 pages/index/index
页面添加 eating
和 morning
两个抽离的公共文件
#
mini.cssLoaderOptioncss-loader 的附加配置。配置项参考官方文档,例如:
#
mini.styleLoaderOptionstyle-loader 的附加配置。配置项参考官方文档,例如:
#
mini.sassLoaderOption自 2.2.8 开始,需要安装
@tarojs/plugin-sass
插件才能使用此配置
sass-loader 的附加配置。配置项参考官方文档,例如:
#
mini.lessLoaderOption自 2.2.8 开始,需要安装
@tarojs/plugin-less
插件才能使用此配置
less-loader 的附加配置。配置项参考官方文档,例如:
#
mini.stylusLoaderOption自 2.2.8 开始,需要安装
@tarojs/plugin-stylus
插件才能使用此配置
stylus-loader 的附加配置。配置项参考官方文档。
#
mini.mediaUrlLoaderOption针对 mp4 | webm | ogg | mp3 | wav | flac | aac
文件的 url-loader 配置。配置项参考官方文档,例如:
#
mini.fontUrlLoaderOption针对 woff | woff2 | eot | ttf | otf
文件的 url-loader 配置。配置项参考官方文档。
#
mini.imageUrlLoaderOption针对 png | jpg | jpeg | gif | bpm | svg
文件的 url-loader 配置。配置项参考官方文档。
#
mini.miniCssExtractPluginOptionmini-css-extract-plugin
的附加配置,在 enableExtract
为 true
的情况下生效。
配置项参考官方文档,例如:
#
mini.postcss配置 postcss
相关插件:
#
h5专属于 H5 的配置。
#
h5.devServer预览服务的配置,可以更改端口等参数。具体配置参考 webpack-dev-server。
默认是 http
服务,如果想开启 https
服务需要做如下配置。
#
h5.output输出配置
#
h5.publicPath设置输出解析文件的目录。
#
h5.staticDirectoryh5 编译后的静态文件目录。
#
h5.chunkDirectory编译后非 entry 的 js 文件的存放目录,主要影响动态引入的 pages
的存放路径。
#
h5.webpackChain自定义 Webpack 配置,接受函数形式的配置。
这个函数会收到两个参数,第一个参数是 webpackChain 对象,可参考 webpack-chain 的 api 进行修改;第二个参数是 webpack
实例。例如:
#
h5.router路由相关的配置,支持路由模式、路由基准路径以及自定义路由的配置。
#
h5.router.mode路由模式配置。配置值为 hash
(默认值)或 browser
,分别对应 hash 路由模式和浏览器 history 路由模式。例子:
针对上面的配置,调用 Taro.navigateTo({ url: '/pages/index/index' })
后,浏览器地址栏将被变为 https://{{domain}}/#/pages/index/index
(hash 模式)或者 https://{{domain}}/pages/index/index
(browser 模式)。
#
h5.router.basename路由基准路径的配置,配置值为 string
类型。例子:
针对上面的配置,调用 Taro.navigateTo({ url: '/pages/index/index' })
后,浏览器地址栏将被变为 https://{{domain}}/#/myapp/pages/index/index
(hash 模式)或者 https://{{domain}}/myapp/pages/index/index
(browser 模式)。
#
h5.router.customRoutes自定义路由的配置,配置值为 { [key: string]: string }
类型。例子:
针对上面的配置,调用 Taro.navigateTo({ url: '/pages/index/index' })
后,浏览器地址栏将被变为 https://{{domain}}/#/index
(hash 模式)或者 https://{{domain}}/myapp/index
(browser 模式)。
#
h5.entryTaro app 的入口,同 webpack.entry。
#
h5.enableSourceMapsourceMap 开关,影响 js、css 的 sourceMap 配置。 dev 状态默认 开,prod 状态默认 关。
#
h5.sourceMapTypesourceMap格式, 默认cheap-module-eval-source-map。具体配置
#
h5.enableExtractextract 功能开关,开启后将使用 mini-css-extract-plugin
分离 css 文件,
可通过 h5.miniCssExtractPluginOption
对插件进行配置。
dev 状态默认 关,prod 状态默认 开。
#
h5.esnextModules配置需要额外的编译的源码模块,比如 taro-ui:
#
h5.cssLoaderOptioncss-loader 的附加配置。配置项参考官方文档,例如:
#
h5.styleLoaderOptionstyle-loader 的附加配置。配置项参考官方文档,例如:
#
h5.sassLoaderOption自 2.2.8 开始,需要安装
@tarojs/plugin-sass
插件才能使用此配置
sass-loader 的附加配置。配置项参考官方文档,例如:
#
h5.lessLoaderOption自 2.2.8 开始,需要安装
@tarojs/plugin-less
插件才能使用此配置
less-loader 的附加配置。配置项参考官方文档,例如:
#
h5.stylusLoaderOption自 2.2.8 开始,需要安装
@tarojs/plugin-stylus
插件才能使用此配置
stylus-loader 的附加配置。配置项参考官方文档。
#
h5.mediaUrlLoaderOption针对 mp4 | webm | ogg | mp3 | wav | flac | aac
文件的 url-loader 配置。配置项参考官方文档,例如:
#
h5.fontUrlLoaderOption针对 woff | woff2 | eot | ttf | otf
文件的 url-loader 配置。配置项参考官方文档。
#
h5.imageUrlLoaderOption针对 png | jpg | jpeg | gif | bpm | svg
文件的 url-loader 配置。配置项参考官方文档。
#
h5.miniCssExtractPluginOptionmini-css-extract-plugin
的附加配置,在 enableExtract
为 true
的情况下生效。
配置项参考官方文档,例如:
#
h5.postcss配置 H5 的 postcss
插件。
#
h5.postcss.autoprefixer可以进行 autoprefixer
的配置。配置项参考官方文档,例如:
#
h5.postcss.pxtransform可以进行 pxtransform
的配置。配置项参考官方文档,例如:
#
h5.postcss.cssModules可以进行 H5 端 CSS Modules 配置,配置如下:
#
rn专属于 RN 的配置。
#
rn.appJSONReact Native 的 app.json 配置。
#
rn.compileRN 编译过程的相关配置。
#
rn.compile.exclude配置 RN 编译过程中排除不需要经过 Taro 编译的文件,数组类型,数组里面可以包含具体文件路径,也可以是判断函数,同 Rule.exclude
例如,想要排除某个文件,可以如下配置要排除的文件具体路径:
也可以配置判断函数,如下
#
rn.compile.include配置额外需要经过 Taro 编译的文件,例如 Taro 默认不编译 node_modules
包中文件,可以通过这个配置让 Taro 编译 node_modules
包中文件,使用方式与 rn.compile.exclude
一致,同 Rule.include。
#
rn.webpackChain自定义 Webpack 配置,接受函数形式的配置。
这个函数会收到三个参数,第一个参数是 webpackChain 对象,可参考 webpack-chain 的 api 进行修改;第二个参数是 webpack
实例;第三个参数 PARSE_AST_TYPE
是小程序编译时的文件类型集合。例如:
注意:第三个参数的取值如下
#
rn.cssLoaderOptioncss-loader 的附加配置。配置项参考官方文档,例如:
#
rn.styleLoaderOptionstyle-loader 的附加配置。配置项参考官方文档,例如:
#
rn.sassLoaderOption自 2.2.8 开始,需要安装
@tarojs/plugin-sass
插件才能使用此配置
sass-loader 的附加配置。配置项参考官方文档,例如:
#
rn.lessLoaderOption自 2.2.8 开始,需要安装
@tarojs/plugin-less
插件才能使用此配置
less-loader 的附加配置。配置项参考官方文档,例如:
#
rn.stylusLoaderOption自 2.2.8 开始,需要安装
@tarojs/plugin-stylus
插件才能使用此配置
stylus-loader 的附加配置。配置项参考官方文档。
#
rn.mediaUrlLoaderOption针对 mp4 | webm | ogg | mp3 | wav | flac | aac
文件的 url-loader 配置。配置项参考官方文档,例如:
#
rn.fontUrlLoaderOption针对 woff | woff2 | eot | ttf | otf
文件的 url-loader 配置。配置项参考官方文档。
#
rn.imageUrlLoaderOption针对 png | jpg | jpeg | gif | bpm | svg
文件的 url-loader 配置。配置项参考官方文档。
#
rn.miniCssExtractPluginOptionmini-css-extract-plugin
的附加配置,在 enableExtract
为 true
的情况下生效。
配置项参考官方文档,例如:
#
rn.postcss配置 postcss
相关插件: