配置文件 
Fes.js 内置了比较通用的构建方式,如果没有个性化需求,不需要修改构建相关的配置。
配置文件解析 
Fes.js 会自动解析项目根目录下的 .fes.js 文件。
最基础的配置文件是这样的:
// .fes.js
export default {};可以通过环境变量 FES_ENV 进行环境差异化配置,当我们运行 FES_ENV=prod fes dev 时,Fes.js 会找到 .fes.js 和 .fes.prod.js(可选) 的配置文件进行 deepmerge。
配置智能提示 
可以通过 defineBuildConfig 工具函数获取类型提示:
import { defineBuildConfig } from '@fesjs/fes';
export default defineBuildConfig({});共享配置 
alias 
类型:
object默认值:
{}详情:
配置别名,对引用路径进行映射。
示例:
export default {
    alias: {
        main: 'src/assets/styles/main',
    },
};然后 import('main'),实际上是 import('src/assets/styles/main')。
autoprefixer 
- 类型: 
object - 默认值:
 
{
    flexbox: 'no-2009';
}详情:
base 
类型:
string默认值:
''详情:
设置路由前缀,通常用于部署到非根目录。比如你有路由
/pageA、/pageB,然后设置了base为/manage/,那么就可以通过/manage/pageA、/manage/pageB访问到它们。
2.1.x 已废弃
2.1.x 版本请使用 router.base 代替
builder 
- 类型: 
string - 默认值: 如果装了多个构建,需要通过 builder 指定具体使用哪个
 - 详情: 比如 dev 用 vite,构建用 webpack
 - 示例:
 
export default {
    builder: 'webpack',
};console 
- 类型: 
object - 默认值:
{} - 详情: 用于控制应用启动的时候在 console 中打印的信息,目前仅支持 version
 - 示例:
 
export default {
    console: {
        version: true
    }
};define 
- 类型: 
object - 默认值: 
{} - 详情: 用于提供给代码中可用的变量。
 - 示例:
 
export default {
    define: {
        __DEV__: 'development',
    },
};然后你代码里写 console.log(__DEV__),会被编译成 console.log('development')。
dynamicImport 
类型:
boolean默认值: false
详情:
路由是否按需加载
inlineLimit 
类型:
number默认值:
8192(8k)详情:
配置图片文件是否走 base64 编译的阈值。默认是
8192字节,小于它会被编译为 base64 编码,否则会生成单独的文件。
globalCSS 
类型:
beforeImports|afterImports默认值:
afterImports详情:
定义 globalCSS 的位置,处理一些 CSS 覆盖问题。
mock 
类型:
object || boolean默认值:
{}详情:
配置 mock 属性。
- 当 mock 为 
boolean类型时,true表示打开 mock,false表示关闭 mock。 - 当 mock 为 
object类型时,默认打开 mock。也可以通过子属性prefix添加过滤条件,满足条件的走 mock 文件。 
- 当 mock 为 
 示例:
export default {
    mock: {
        prefix: '/api/auth',
    },
};然后所有以 /api/users 开始的请求,就能进入 mock.js 文件处理,mock.js 示例。
mountElementId 
类型:
string默认值:
app详情:
指定渲染到的 HTML 元素 id。
outputPath 
类型:
string默认值:
dist详情:
指定输出路径。
TIP
不允许设定为 src、public、pages 等约定目录。
plugins 
类型:
Array(string)默认值:
[]详情:
配置额外的
fes插件。 数组项为指向插件的路径,可以是 npm 依赖、相对路径或绝对路径。如果是相对路径,则会从项目根目录开始找。示例:
export default {
    plugins: [
        // npm 依赖
        'fes-plugin-hello',
        // 相对路径
        './plugin',
        // 绝对路径
        `${__dirname}/plugin.js`,
    ],
};proxy 
类型:
object默认值:
{}详情:
配置代理能力。
示例:
export default {
    proxy: {
        '/v2': {
            target: 'https://api.douban.com/',
            changeOrigin: true,
        },
    },
};然后访问 /v2/movie/in_theaters_proxy 就能访问到 http://api.douban.com/v2/movie/in_theaters_proxy 的数据。
publicPath 
类型:
string默认值:
/详情:
静态资源 publicPath。当打包的时候在静态文件路径前面添加
publicPath的值,当你需要修改静态文件地址时,比如使用 CDN 部署,把publicPath的值设为 CDN 的值就可以。
router 
类型:
object默认值:
{ mode: 'hash', base: '/' }详情:
配置路由,具体请查看指南中关于路由的介绍
singular 
类型:
boolean默认值:
false详情:
配置是否启用单数模式的目录。 比如
src/pages的约定在开启后为src/page目录,@fesjs/fes-plugins 插件也遵照此配置的约定。
targets 
类型:
object默认值:
{}详情:
配置需要兼容的浏览器最低版本,会自动引入 polyfill 和做语法转换。
terserOptions 
- 类型: 
object - 默认值:
 
const defaultTerserOptions = {
    compress: {
        // turn off flags with small gains to speed up minification
        arrows: false,
        collapse_vars: false, // 0.3kb
        comparisons: false,
        computed_props: false,
        hoist_funs: false,
        hoist_props: false,
        hoist_vars: false,
        inline: false,
        loops: false,
        negate_iife: false,
        properties: false,
        reduce_funcs: false,
        reduce_vars: false,
        switches: false,
        toplevel: false,
        typeofs: false,
        // a few flags with noticeable gains/speed ratio
        // numbers based on out of the box vendor bundle
        booleans: true, // 0.7kb
        if_return: true, // 0.4kb
        sequences: true, // 0.7kb
        unused: true, // 2.3kb
        // required features to drop conditional branches
        conditionals: true,
        dead_code: true,
        evaluate: true,
    },
    mangle: {
        safari10: true,
    },
};详情:
title 
类型:
string详情:
html 页面标题
webpack 专属配置 
analyze 
- 类型: 
object - 默认值:
 
{
    analyzerMode: process.env.ANALYZE_MODE || 'server',
    analyzerPort: process.env.ANALYZE_PORT || 8888,
    openAnalyzer: process.env.ANALYZE_OPEN !== 'none',
    // generate stats file while ANALYZE_DUMP exist
    generateStatsFile: !!process.env.ANALYZE_DUMP,
    statsFilename: process.env.ANALYZE_DUMP || 'stats.json',
    logLevel: process.env.ANALYZE_LOG_LEVEL || 'info',
    defaultSizes: 'parsed' // stat  // gzip
}详情:
构建结果分析,当配置
p时开启,例如执行rocess.env.ANALYZE ANALYZE=1 fes build
chainWebpack 
类型:
function默认值:
null详情:
通过 webpack-chain 的 API 修改 webpack 配置。
示例:
export default {
    chainWebpack(memo, { env, webpack }) {
        // 删除 fes 内置插件
        memo.plugins.delete('copy');
    },
};cssLoader 
类型:
object默认值:
''详情:
设置 css-loader 配置项。
copy 
类型:
Array(string) || Array(object)默认值:
[]详情:
设置要复制到输出目录的文件、文件夹。
配置约定
from-to规则, 其中from是相对于cwd的路径,to是相对于输出路径的路径。示例:
export default {
    copy: {
        from: '/src/assets/images',
        to: 'assets/images',
    },
};上面示例中,实现了将 cwd 路径中的 /src/assets/images 文件夹,在编译完成后,copy 到输出路径下的 assets/images 文件夹。
devServer 
类型:
object默认值:
{}详情:
配置开发服务器。支持以下子配置项:
- port,端口号,默认 
8000 - host,默认 
localhost - https,是否启用 https server,同时也会开启 HTTP/2
 
启用 port 和 host 也可以通过环境变量
PORT和HOST临时指定。- port,端口号,默认 
 
devtool 
类型:
string默认值:
cheap-module-source-mapin dev,undefinedin build详情:
用户配置 sourcemap 类型。详见 webpack#devtool 配置。
extraCSS 
类型:
object默认值:
{}详情:
配置如何使用
mini-css-extract-plugin,默认使用插件的默认配置。loader选项对应 loader 参数,plugin选项对应插件参数。例如:
export default {
    // 配置 mini-css-extract-plugin
    extraCSS: {
        loader: {
            publicPath: (resourcePath, context) => `${path.relative(path.dirname(resourcePath), context)}/`,
        },
    },
};exportStatic 
- 类型: 
object - 默认值: 
{} - 详情:
 
配置 html 的输出形式,默认只输出 index.html。
如果开启 exportStatic,则会针对每个路由输出 html 文件。
比如以下路由,
/
/users
/list不开启 exportStatic 时,输出,
- index.html设置 exportStatic: {} 后,输出,
- index.html
- users.html
- list.htmlexternals 
类型:
object默认值:
{}详情:
设置哪些模块可以不被打包,通过
<script>或其他方式引入。
示例:
export default {
    externals: {
        vue: 'window.Vue',
    },
};extraBabelPlugins 
- 类型: 
array - 默认值: 
[] - 详情:
 
配置额外的 babel 插件。
- 示例:
 
export default {
    extraBabelPlugins: [['import', { libraryName: 'ant-design-vue', libraryDirectory: 'es', style: 'css' }]],
};extraBabelPresets 
- 类型: 
array - 默认值: 
[] - 详情:
 
配置额外的 babel 插件集。
extraPostCSSPlugins 
类型:
array默认值:
[]详情:
设置额外的 postcss 插件。
html 
类型:
object默认值:
{}详情:
lessLoader 
类型:
object默认值:
{}详情:
设置 less-loader 配置项。
nodeModulesTransform 
类型:
object默认值:
{ exclude: [] }详情:
默认编译所有
node_modules下的包,可以通过配置exclude来跳过某些包,以提高编译速度。
postcssLoader 
类型:
object默认值:
{}详情:
vueLoader 
类型:
object默认值:
{}详情:
配置 Vue Loader
Vite 专属配置 
viteOption 
类型:
object详情:
Vite 的配置,详情请看 Vite Config
viteVuePlugin 
类型:
object详情:
自定义 @vitejs/plugin-vue 的配置。
viteVueJsx 
类型:
object详情:
自定义 @vitejs/plugin-vue-jsx 的配置。
viteLegacy 
类型:
object详情:
自定义 @vitejs/plugin-legacy 的配置。
viteHtml 
类型:
object详情:
自定义 vite-plugin-html 的配置。
更多配置项 
Fes.js 允许插件注册配置,如果你使用插件,肯定会在插件里找到更多配置项。
Fes.js