这是所有 Vue CLI 项目默认的 Babel 预设选项。
- @babel/preset-env
modules: false
- 在 Jest 测试中会自动设置为
'commonjs'
- 在 Jest 测试中会自动设置为
useBuiltIns: 'usage'
- 确保 polyfill 会按需导入
targets
的判断规则:- 为浏览器构建时使用
package.json
中的browserslist
字段 - 在 Node.js 中运行测试时设置为
{ node: 'current' }
- 为浏览器构建时使用
- 默认包含
Promsie
polyfill,这样它们也可以用于非转译依赖 (只用于必要的环境) - @babel/plugin-transform-runtime
- 只为 polyfill 被
babel-preset-env
处理时开启供帮助用
- 只为 polyfill 被
- 动态导入语法
- Object rest spread
- babel-preset-stage-2
- Vue JSX 语法支持
- @babel/plugin-syntax-jsx
- babel-plugin-transform-vue-jsx
babel-plugin-jsx-event-modifiers(在 Babel 7 修复之前暂时不可用)babel-plugin-jsx-v-model(在 Babel 7 修复之前暂时不可用)
- 默认值:
false
当用 webpack 构建时'commonjs'
当在 Jest 中运行测试时
为 babel-preset-env
显性设置 modules
选项。请查阅 babel-preset-env 文档 了解更多详情。
- 默认值:
- 当为浏览器构建时,由
package.json
中的browserslist
字段决定 - 在 Node.js 中运行测试时设置为
{ node: 'current' }
- 当为浏览器构建时,由
为 babel-preset-env
显性设置 targets
选项。请查阅 babel-preset-env 文档 了解更多详情。
- 默认值:
'usage'
为 babel-preset-env
显性设置 useBuiltIns
选项。
默认值是 'usage'
,它会基于被转译代码的使用情况导入相应的 polyfill。例如,你在代码里使用了 Object.assign
,那么如果你的目标环境不支持它,对应的 polyfill 就会被自动导入。
注意用法侦测并不适用于你的依赖 (它们默认被 cli-plugin-babel
排除在外)。如果你的一个依赖需要 polyfill,可以选择:
-
**如果这个依赖是用一个你的目标环境不支持的 ES 版本撰写的:**请把那个依赖添加到
vue.config.js
的transpileDependencies
选项中。它会为这个依赖开启语法转换和基于用法的 polyfill 侦测。 -
**如果这个依赖交付 ES5 代码并显式地列出了需要的 polyfill:**你可以使用 polyfills 选项为这个预设选项预包含所需要的 polyfill。
-
如果这个依赖交付 ES5 代码,但是使用了没有显性列出的 ES6+ 特性的 polyfill 需求 (例如 Vuetify):请使用
useBuiltIns: 'entry'
并将import '@babel/polyfill'
添加到你的入口文件中。它会基于你的browserlist
目标导入所有的 polyfill,所以你无需再担心任何依赖中的 polyfill,不过因为它加入了一些未被使用的 polyfill,最终的包体积会增加。
查阅 @babel/preset-env 文档了解更多细节。
- 默认值:
['es6.promise']
当使用 useBuiltIns: 'usage'
的时候预包含的一份 core-js polyfill 的列表。如果你的目标环境不需要,这些 polyfill 会自动被排除。
当你拥有未被 Babel 处理但是需要特定的 polyfill 的第三方依赖时 (例如 Axios 和 Vuex 需要 Promise 的支持) 请使用这个选项。
- 默认值:
true
。设为false
可以禁用 JSX 支持。
- 默认值:
false
。设置为true
时会生成更高效但少一些规范性的代码。