vue-cli脚手架的.babelrc文件用法说明
虽然es6还没被浏览器全部支持,但是使用es6是大势所趋,所以babel应运而生将es6代码转换成浏览器能够识别的代码
什么是.babelrc文件呢?熟悉linux的同学一定知道,rc结尾的文件通常代表运行时自动加载的文件,配置等等,类似bashrc,zshrc
这个文件是用来设置转码的规则和插件
vue-cli脚手架的.babelrc文件
{ //此项指明,转码的规则 "presets":[ //env项是借助插件babel-preset-env,下面这个配置说的是babel对es6,es7,es8进行转码,并且设置amd,commonjs这样的模块化文件,不进行转码 ["env",{ "modules":false, "targets":{//需要支持的环境 "browsers":[">1%","last2versions","notie<=8"] } }], //下面这个是不同阶段出现的es语法,包含不同的转码插件 //stage-x和es2015等有些类似,但是它是按照JavaScript的提案阶段区分的,一共有5个阶段。 //而数字越小,阶段越靠后,存在依赖关系。也就是说stage-0是包括stage-1的,以此类推。 "stage-2" ], //下面这个选项是引用插件来处理代码的转换,transform-runtime用来处理全局函数和优化babel编译,强烈推荐使用transform-runtime "plugins":["transform-runtime"], //下面指的是在生成的文件中,不产生注释 "comments":false, //下面这段是在特定的环境中所执行的转码规则,当环境变量是下面的test就会覆盖上面的设置 "env":{ //test是提前设置的环境变量,如果没有设置BABEL_ENV则使用NODE_ENV,如果都没有设置默认就是development "test":{ "presets":["env","stage-2"], //instanbul是一个用来测试转码后代码的工具 "plugins":["istanbul"] } } }
browserslist:Librarytosharesupportedbrowserslistbetweendifferentfront-endtools.Itisusedin:
Autoprefixer
babel-preset-env
eslint-plugin-compat
stylelint-no-unsupported-browser-features
postcss-normalize
补充知识:vuecli3element-ui懒加载按需加载ui组件
前言
vuecli3.x+UI框架开发时,经常实际只用到的UI框架提供的几个组件,而每次我们是全部引入,这会照成程序需要消耗更多的资源,尤其是在移动端(例如使用mintui),在性能上会有更大的影响,照成不好的用户体验。
接下来记录以vuecli3.x+elementui为例实现按需加载组件。
未引入element插件时
引入elementui(npmielement-ui-S)
如下图,可见app.js增加了5M的数据。
//main.js importElementUIfrom'element-ui' import'element-ui/lib/theme-chalk/index.css' Vue.use(ElementUI)
只引入element的部分组件
如下图,可见虽然我们只引用了两个组件,但是app.js的大小几乎不变,这样没有实现按需加载的效果。
import{Button,Select}from'element-ui' //此时的样式必须要引入,否则组件将没有样式 import'element-ui/lib/theme-chalk/index.css' Vue.use(Button) Vue.use(Select)
实现按需加载
1.安装插件npmibabel-plugin-component-D
2.配置babel.config.js
module.exports={ presets:[ '@vue/app', ['@babel/preset-env',//添加babel-preset-env配置 { 'modules':false } ] ], plugins:[ [ 'component', { 'libraryName':'element-ui',//按需引入的组件库 'styleLibraryName':'theme-chalk'//按需引入的样式 } ] ] }
把main.js也修改下:
import{Button,Select}from'element-ui' //此时的样式不需要引入了,样式自动按需来引入 //import'element-ui/lib/theme-chalk/index.css' Vue.use(Button) Vue.use(Select) Vue.config.productionTip=false newVue({ router, render:h=>h(App) }).$mount('#app')
配置好后重新npmrunserve下,此时的app.js相对于没有引入插件时只增加了几百k的大小,这样就实现了按需加载。
以上这篇vue-cli脚手架的.babelrc文件用法说明就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。