一:通过browserslist来指定项目的目标浏览器范围,编译时会根据配置的目标浏览器来有针对性的转义;
-
参考地址:vue-cli官网介绍
//例如在package.json中的配置
//这个值会被 @babel/preset-env 和 Autoprefixer 用来确定需要转译的 JavaScript 特性和需要添加的 CSS 浏览器前缀。
{
"private": true,
"dependencies": {
"autoprefixer": "^6.5.4"
},
"browserslist": [ //配置要兼容的浏览器,符合下面搜索条件的所有浏览器都可以自动兼容进行前缀等注入兼容。
"last 1 version", //所有浏览器兼容到最后1个版本根据CanIUse.com追踪的版本
"> 1%", //全球超过1%人使用的浏览器
"IE 10" //要兼容ie10
]
} -
各种 browserslist 的配置的意思:
-
例子 说明 > 1%
全球超过1%人使用的浏览器 > 5% in US
指定国家使用率覆盖 last 2 versions
所有浏览器兼容到最后两个版本根据CanIUse.com追踪的版本 Firefox ESR
火狐最新版本 Firefox > 20
指定浏览器的版本范围 not ie <=8
方向排除部分版本 Firefox 12.1
指定浏览器的兼容到指定版本 unreleased versions
所有浏览器的beta测试版本 unreleased Chrome versions
指定浏览器的测试版本 since 2013
2013年之后发布的所有版本 -
参考地址 cli-babel-preset-app
//根目录下的babel.config.js配置
//安装dev "@vue/cli-plugin-babel": "^4.0.4"
//安装save "core-js": "^3.1.2"
module.exports = {
presets: [
'@vue/cli-plugin-babel/preset',
[
'@babel/preset-env',
{
'useBuiltIns': 'entry',
'corejs': 3
}
]
],
plugins:[]
}
2.1 关于 useBuiltIns 的配置,三个可选项 [false,'entry','usage']
2.1.1."useBuiltIns": false
(此时不对 polyfill 做操作。如果引入 @babel/polyfill,则无视配置的浏览器兼容,引入所有的 polyfill。)
2.1.2."useBuiltIns": "entry","corejs": 2,
(根据配置的浏览器兼容,引入浏览器不兼容的
polyfill
。需要在入口文件手动添加import '@babel/polyfill'
,会自动根据browserslist
替换成浏览器不兼容的所有polyfill
。这里需要指定
core-js
的版本, 如果"corejs": 3
, 则import '@babel/polyfill'
需要改成下面这样:)// 在main.js的头部
import 'core-js/stable';
import 'regenerator-runtime/runtime';2.1.3."useBuiltIns": "usage","corejs": 2,
(
usage
会根据配置的浏览器兼容,以及你代码中用到的 API 来进行polyfill
,实现了按需添加。) -
-