时间:2021-05-26
起源
由Vue-Cli(2.X)生成的Vue项目中存在着首屏加载过慢,编译资源过大等问题,主要针对这些问题对项目进行相应的优化,提升项目响应速度,优化项目性能。
操作
路由懒加载
在Vue-router官方文档中有针对懒加载的介绍,主要是将整个大的js进行切片,对当前路由的资源进行一个按需加载。在Vue-cli生成的路由组件引用方法是这样的
import HelloWorld from '@/components/HelloWorld'只需将组件的引用方式改为
const HelloWorld = () => import ('@/components/HelloWorld')然后重新编译即可
开启预加载/优先加载
使用webpack插件PreloadWebpackPlugin 进行预加载prefetch和优先加载preload。 主要做的是用preload加载vendor、manifest与app三个js而用prefetch去加载所有路由对应的文件。 首先要 安装插件
npm install --save preload-webpack-plugin在webpack.prod.conf.js 中修改,加入预加载的代码 (注意放在new HtmlWebpackPlugin() 的下面)
new PreloadWebpackPlugin({ rel: 'prefetch',}),new PreloadWebpackPlugin({ rel: 'preload', as(entry) { if (/\.css$/.test(entry)) return 'style' return 'script'; }, include: ['app', 'vendor', 'manifest']})开启GZip
gzip,使用gzip压缩资源可以更快地加载资源。客户端http请求头声明浏览器支持的压缩方式,服务端配置启用压缩,压缩的文件类型,压缩方式。当客户端请求到服务端的时候,服务器解析请求头,如果客户端支持gzip压缩,响应时对请求的资源进行压缩并返回给客户端,浏览器按照自己的方式解析,在http响应头,我们可以看到content-encoding:gzip ,这是指服务端使用了gzip的压缩方式。
启用gzip,在nginx的site-conf中开启gzip
server { gzip on; gzip_types text/xml text/css text/plain text/javascript application/javascript application/x-javascript;}webpack处理,需要先安装插件
npm install --save-dev compression-webpack-plugin然后在config的index.js中 ,将productionGzip改为true,开启Gzip压缩。
PS:如果编译报错,则安装compression-webpack-plugin@1.1.12 版本
对第三方工具库进行额外处理
本项目中Vender中主要是Vue,Vue-router,axios等固定依赖的代码,工具库的代码一般不会改动,所以可以将这些工具库的代码抽出来,单独走CDN加载以减少编译JS文件的大小。 具体操作 : 选择相应的工具库版本的cdn,加入到index.html中
<script src="//cdn.bootcss.com/vue/2.2.5/vue.min.js"></script><script src="//cdn.bootcss.com/vue-router/2.3.0/vue-router.min.js"></script><script src="//cdn.bootcss.com/vuex/2.2.1/vuex.min.js"></script><script src="//cdn.bootcss.com/axios/0.15.3/axios.min.js"></script>之后去到webpack中修改相应的打包配置
externals: { 'vue': 'Vue', 'vue-router': 'VueRouter', 'vuex': 'Vuex', 'axios': 'axios'}ps:倘若main.js中有关于公共库的引用 请记得清除掉 这时再去编译 打包 就会发现编译的Vender.js小了很多
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了Vue-CLI与Vuex使用方法。分享给大家供大家参考,具体如下:1、通过Vue-CLI创建项目Vue-CLI是Vue用于创建Vue项目的脚手架工
vue-cli是一个官方发布vue.js项目脚手架,使用vue-cli可以快速创建vue项目,GitHub地址是:https://github.com/vuej
一:环境搭建使用vue-cli脚手架工具构建安装vue-clinpminstall-gvue-cli使用vue-cli初始化项目vueinitdemo1进到目录
本文介绍了Vue使用vue-cli创建项目,分享给大家,具体如下:vue-cli是一个官方发布vueJS项目脚手架:https://github.com/vue
前言vue-cli是一个官方发布vue.js项目脚手架,Vue-cli可以快速帮助我们创建一个项目,这是官方给我们提供的脚手架。下面我说一下vue-cli的使用