---
aside: left
outline: [2, 3]
---

## 配置文件

Fes.js 内置了比较通用的构建方式,如果没有个性化需求,不需要修改构建相关的配置。

### 配置文件解析

Fes.js 会自动解析项目根目录下的 `.fes.js` 文件。

最基础的配置文件是这样的:

```js
// .fes.js
export default {};
```

可以通过环境变量 `FES_ENV` 进行环境差异化配置,当我们运行 `FES_ENV=prod fes dev` 时,Fes.js 会找到 `.fes.js` 和 `.fes.prod.js`(可选) 的配置文件进行 `deepmerge`。

### 配置智能提示

可以通过 `defineBuildConfig` 工具函数获取类型提示:

```js
import { defineBuildConfig } from '@fesjs/fes';

export default defineBuildConfig({});
```

## 共享配置

### alias

-   类型: `object`
-   默认值: `{}`
-   详情:

    配置别名,对引用路径进行映射。

-   示例:

```js
export default {
    alias: {
        main: 'src/assets/styles/main',
    },
};
```

然后 `import('main')`,实际上是 `import('src/assets/styles/main')`。

### autoprefixer

-   类型: `object`
-   默认值:

```js
{
    flexbox: 'no-2009';
}
```

-   详情:

    [postcss autoprefixer 插件](https://github.com/postcss/autoprefixer#options) 配置。

### base

-   类型: `string`
-   默认值: `''`
-   详情:

    设置路由前缀,通常用于部署到非根目录。比如你有路由 `/pageA`、`/pageB`,然后设置了 `base` 为 `/manage/`,那么就可以通过 `/manage/pageA`、`/manage/pageB` 访问到它们。

::: warning 2.1.x 已废弃
2.1.x 版本请使用 router.base 代替
:::

### builder

-   类型: `string`
-   默认值: 如果装了多个构建,需要通过 builder 指定具体使用哪个
-   详情:
    比如 dev 用 vite,构建用 webpack
-   示例:

```js
export default {
    builder: 'webpack',
};
```

### define

-   类型: `object`
-   默认值: `{}`
-   详情:
    用于提供给代码中可用的变量。
-   示例:

```js
export default {
    define: {
        __DEV__: 'development',
    },
};
```

然后你代码里写 `console.log(__DEV__)`,会被编译成 `console.log('development')`。

### dynamicImport

-   类型: `boolean`
-   默认值: false
-   详情:

    路由是否按需加载


### inlineLimit

-   类型: `number`
-   默认值: `8192`(8k)
-   详情:

    配置图片文件是否走 base64 编译的阈值。默认是 `8192` 字节,小于它会被编译为 base64 编码,否则会生成单独的文件。

### mock

-   类型: `object || boolean`
-   默认值: `{}`
-   详情:

    配置 mock 属性。

    -   当 mock 为 `boolean` 类型时,`true` 表示打开 mock,`false` 表示关闭 mock。
    -   当 mock 为 `object` 类型时,默认打开 mock。也可以通过子属性 `prefix` 添加过滤条件,满足条件的走 mock 文件。

-   示例:

```js
export default {
    mock: {
        prefix: '/api/auth',
    },
};
```

然后所有以 `/api/users` 开始的请求,就能进入 mock.js 文件处理,[mock.js 示例](../../guide/mock)。

### mountElementId

-   类型: `string`
-   默认值: `app`
-   详情:

    指定渲染到的 HTML 元素 id。

### outputPath

-   类型: `string`
-   默认值: `dist`
-   详情:

    指定输出路径。

::: tip
不允许设定为 `src`、`public`、`pages` 等约定目录。
:::

### plugins

-   类型: `Array(string)`
-   默认值: `[]`
-   详情:

    配置额外的 `fes` 插件。
    数组项为指向插件的路径,可以是 npm 依赖、相对路径或绝对路径。如果是相对路径,则会从项目根目录开始找。

-   示例:

```js
export default {
    plugins: [
        // npm 依赖
        'fes-plugin-hello',
        // 相对路径
        './plugin',
        // 绝对路径
        `${__dirname}/plugin.js`,
    ],
};
```

### proxy

-   类型: `object`
-   默认值: `{}`
-   详情:

    配置代理能力。

-   示例:

```js
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](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`
-   默认值:

```js
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,
    },
};
```

-   详情:

    配置 [压缩器 terser 的配置项](https://github.com/terser/terser#minify-options)

### title

-   类型: `string`
-   详情:

    html 页面标题

## webpack 专属配置

### analyze

-   类型: `object`
-   默认值:

```js
{
    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
}
```

-   详情:

    构建结果分析,当配置 `process.env.ANALYZE` 时开启,例如执行`ANALYZE=1 fes build`

### chainWebpack

-   类型:`function`
-   默认值:`null`
-   详情:

    通过 [webpack-chain](https://github.com/sorrycc/webpack-chain#readme) 的 API 修改 webpack 配置。

示例:

```js
export default {
    chainWebpack(memo, { env, webpack }) {
        // 删除 fes 内置插件
        memo.plugins.delete('copy');
    },
};
```

### cssLoader

-   类型: `object`
-   默认值: `''`
-   详情:

    设置 [css-loader 配置项](https://github.com/webpack-contrib/css-loader#options)。

### copy

-   类型: `Array(string) || Array(object)`
-   默认值: `[]`
-   详情:

    设置要复制到输出目录的文件、文件夹。

    配置约定 `from-to` 规则, 其中 `from` 是相对于 `cwd` 的路径,`to` 是相对于输出路径的路径。

-   示例:

```js
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` 临时指定。

### devtool

-   类型: `string`
-   默认值: `cheap-module-source-map` in dev, `undefined` in build
-   详情:

    用户配置 sourcemap 类型。详见 [ webpack#devtool 配置](https://webpack.js.org/configuration/devtool/#devtool)。

### extraCSS

-   类型: `object`
-   默认值: `{}`
-   详情:

    配置如何使用`mini-css-extract-plugin`,默认使用插件的默认配置。`loader` 选项对应loader参数,`plugin`选项对应插件参数。例如:

```js
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.html
```

### externals

-   类型:`object`
-   默认值:`{}`
-   详情:

    设置哪些模块可以不被打包,通过 `<script>` 或其他方式引入。

示例:

```js
export default {
    externals: {
        vue: 'window.Vue',
    },
};
```

### extraBabelPlugins

-   类型: `array`
-   默认值: `[]`
-   详情:

配置额外的 `babel` 插件。

-   示例:

```js
export default {
    extraBabelPlugins: [['import', { libraryName: 'ant-design-vue', libraryDirectory: 'es', style: 'css' }]],
};
```

### extraBabelPresets

-   类型: `array`
-   默认值: `[]`
-   详情:

配置额外的 `babel` 插件集。

### extraPostCSSPlugins

-   类型: `array`
-   默认值: `[]`
-   详情:

    设置额外的 [postcss 插件](https://github.com/postcss/postcss/blob/master/docs/plugins.md)。

### html

-   类型: `object`
-   默认值: `{}`
-   详情:

    设置[html-webpack-plugin](https://github.com/jantimon/html-webpack-plugin#options)。

### lessLoader

-   类型: `object`
-   默认值: `{}`
-   详情:

    设置 [less-loader 配置项](https://github.com/webpack-contrib/less-loader)。

### nodeModulesTransform

-   类型: `object`
-   默认值: `{ exclude: [] }`
-   详情:

    默认编译所有 `node_modules` 下的包,可以通过配置 `exclude` 来跳过某些包,以提高编译速度。

### postcssLoader

-   类型: `object`
-   默认值: `{}`
-   详情:

    设置 [postcss-loader 配置项](https://github.com/postcss/postcss-loader#options)。

### vueLoader

-   类型: `object`
-   默认值:`{}`
-   详情:

    配置 [Vue Loader](https://vue-loader.vuejs.org/zh/options.html)

## Vite 专属配置

### viteOption

-   类型: `object`
-   详情:

    Vite 的配置,详情请看 [Vite Config](https://cn.vitejs.dev/config/)

### viteVuePlugin

-   类型: `object`
-   详情:

    自定义 [@vitejs/plugin-vue](https://github.com/vitejs/vite/tree/main/packages/plugin-vue) 的配置。

### viteVueJsx

-   类型: `object`
-   详情:

    自定义 [@vitejs/plugin-vue-jsx](https://github.com/vitejs/vite/tree/main/packages/plugin-vue-jsx) 的配置。

### viteLegacy

-   类型: `object`
-   详情:

    自定义 [@vitejs/plugin-legacy](https://github.com/vitejs/vite/tree/main/packages/plugin-legacy) 的配置。

### viteHtml

-   类型: `object`
-   详情:

    自定义 [vite-plugin-html](https://github.com/vbenjs/vite-plugin-html) 的配置。

## 更多配置项

Fes.js 允许插件注册配置,如果你使用插件,肯定会在插件里找到更多配置项。