单页应用会随着项目越大,导致首屏加载速度很慢!!!以下给出在下知道的几种优化方案
- 使用CDN资源,减小服务器带宽压力
- 路由懒加载
- 将一些静态js css放到其他地方(如OSS),减小服务器压力
- 按需加载三方资源,如iview,建议按需引入iview中的组件
- 使用Nginx开启gzip减小网络传输的流量大小
- webpack开启gzip压缩
- 若首屏为登录页,可以做成多入口,登录页单独分离为一个入口
使用CDN资源,减小服务器带宽压力
在index.html中引入cdn资源
...
修改 build/webpack.base.conf.js
修改src/main.js src/router/index.js 注释掉import引入的vue,vue-resource
注意这里的js文件,需要将结果抛出,然后在需要用到该js的组件中import引入
按需引用请查看iview官方文档iview
配置Nginx,可以参考Nginx开启Gzip压缩大幅提高页面加载速度
config/index.js中
build/webpack.prod.conf.js中
使用vue-cli构建项目时,默认会有这段代码
在原先只有一个入口叫app的基础上,再加一个叫login的入口,指向另一个入口js文件;
既然是两个页面,那么原先只有一个的HtmlWebpackPlugin也需要再添加一个,并且filename和template改成登录页的;
HtmlWebpackPlugin默认会把所有资源放进html,为了去掉不需要的资源,需要在HtmlWebpackPlugin选项里分别添加excludeChunks: ['login']和excludeChunks: ['app'];
原先的某些CommonsChunkPlugin会导致报错,删掉只剩下一个manifest的CommonsChunkPlugin就好。
添加之前配好的login入口文件,与app类似,但是去掉登录页不需要的东西,如用不到的组件和样式等;
添加login入口专用的router配置文件,去掉其他路由,只留下登录页一个就好:
登录路由
登录完不是用vue-router的push方法,而是改成直接修改location.href跳到另一个页面;
去除原来app路由中的login;
登录页中可以使用隐藏的iframe等方式预加载app页面中的数据(猜想)。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。
原文链接:https://www.f2er.com/vue/30677.html