浅谈VUE单页应用首屏加载速度优化方案


Posted in Javascript onAugust 28, 2018

单页应用会随着项目越大,导致首屏加载速度很慢!!!以下给出在下知道的几种优化方案

  • 使用CDN资源,减小服务器带宽压力
  • 路由懒加载
  • 将一些静态js css放到其他地方(如OSS),减小服务器压力
  • 按需加载三方资源,如iview,建议按需引入iview中的组件
  • 使用nginx开启gzip减小网络传输的流量大小
  • webpack开启gzip压缩
  • 若首屏为登录页,可以做成多入口,登录页单独分离为一个入口

使用CDN资源,减小服务器带宽压力

在index.html中引入cdn资源

...
 <body>
  <div id="app">
  </div>
  <!-- built files will be auto injected -->
  <script src="https://cdn.bootcss.com/vue/2.5.2/vue.min.js"></script>
  <script src="https://cdn.bootcss.com/vue-router/3.0.1/vue-router.min.js"></script>
  <script src="https://cdn.bootcss.com/vuex/3.0.1/vuex.min.js"></script>
  <script src="https://cdn.bootcss.com/vue-resource/1.5.1/vue-resource.min.js"></script>
 </body>
 ...

修改 build/webpack.base.conf.js

module.exports = {
 context: path.resolve(__dirname, '../'),
 entry: {
  app: './src/main.js'
 },
 externals:{
  'vue': 'Vue',
  'vue-router': 'VueRouter',
  'vuex':'Vuex',
  'vue-resource': 'VueResource'
 },
 ...
}

修改src/main.js src/router/index.js 注释掉import引入的vue,vue-resource

// import Vue from 'vue'
// import VueResource from 'vue-resource'
// Vue.use(VueResource)

路由懒加载

const workCircle = r => require.ensure([], () => r(require('@/module/work-circle/Index')), 'workCircle')
const workCircleList = r => require.ensure([], () => r(require('@/module/work-circle/page/List')), 'workCircleList')

将一些静态js css放到其他地方(如OSS),减小服务器压力

注意这里的js文件,需要将结果抛出,然后在需要用到该js的组件中import引入

按需加载三方资源,如iview,建议按需引入iview中的组件

按需引用请查看iview官方文档iview

使用nginx开启gzip减小网络传输的流量大小

配置nginx,可以参考Nginx开启Gzip压缩大幅提高页面加载速度

webpack开启gzip压缩

这里需要配合Nginx服务器,Nginx开启gzip

config/index.js中

module.exports = {
 build: {
  ...
  // Gzip off by default as many popular static hosts such as
  // Surge or Netlify already gzip all static assets for you.
  // Before setting to `true`, make sure to:
  // npm install --save-dev compression-webpack-plugin
  productionGzip: true, // 就是这里开启gzip,vue-cli搭建项目,这里默认为false
  productionGzipExtensions: ['js', 'css'],

  // Run the build command with an extra argument to
  // View the bundle analyzer report after build finishes:
  // `npm run build --report`
  // Set to `true` or `false` to always turn it on or off
  bundleAnalyzerReport: process.env.npm_config_report
 }
}

build/webpack.prod.conf.js中

使用vue-cli构建项目时,默认会有这段代码

if (config.build.productionGzip) {
 const CompressionWebpackPlugin = require('compression-webpack-plugin')
 webpackConfig.plugins.push(
  new CompressionWebpackPlugin({
   asset: '[path].gz[query]',
   algorithm: 'gzip',
   test: new RegExp(
    '\\.(' +
    config.build.productionGzipExtensions.join('|') +
    ')$'
   ),
   threshold: 10240,
   minRatio: 0.8
  })
 )
}

若首屏为登录页,可以做成多入口,登录页单独分离为一个入口

修改webpack配置

在原先只有一个入口叫app的基础上,再加一个叫login的入口,指向另一个入口js文件;

既然是两个页面,那么原先只有一个的HtmlWebpackPlugin也需要再添加一个,并且filename和template改成登录页的;

HtmlWebpackPlugin默认会把所有资源放进html,为了去掉不需要的资源,需要在HtmlWebpackPlugin选项里分别添加excludeChunks: ['login']和excludeChunks: ['app'];

原先的某些CommonsChunkPlugin会导致报错,删掉只剩下一个manifest的CommonsChunkPlugin就好。

添加登录相关文件

添加之前配好的login入口文件,与app类似,但是去掉登录页不需要的东西,如用不到的组件和样式等;

添加login入口专用的router配置文件,去掉其他路由,只留下登录页一个就好:

浅谈VUE单页应用首屏加载速度优化方案

只留登录路由

添加登录页的html模板,也是去掉登录里用不到的资源。

修改其他细节

登录完不是用vue-router的push方法,而是改成直接修改location.href跳到另一个页面;

去除原来app路由中的login;

登录页中可以使用隐藏的iframe等方式预加载app页面中的数据(猜想)。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript实现的动态添加表单元素input,button等(appendChild)
Nov 24 Javascript
JavaScript验证电子邮箱的函数
Aug 22 Javascript
js通过location.search来获取页面传来的参数
Sep 11 Javascript
javascript复制粘贴与clipboardData的使用
Oct 16 Javascript
浅析JavaScript动画
Jun 10 Javascript
最常见的左侧分类菜单栏jQuery实现代码
Nov 28 Javascript
详解vue-cli构建项目反向代理配置
Sep 07 Javascript
Angular客户端请求Rest服务跨域问题的解决方法
Sep 19 Javascript
基于vue-cli创建的项目的目录结构及说明介绍
Nov 23 Javascript
如何在基于vue-cli的项目自定义打包环境
Nov 10 Javascript
图片文字识别(OCR)插件Ocrad.js教程
Nov 26 Javascript
vue 监听 Treeselect 选择项的改变操作
Aug 31 Javascript
浅谈redux以及react-redux简单实现
Aug 28 #Javascript
Vue封装的可编辑表格插件方法
Aug 28 #Javascript
JavaScript使用递归和循环实现阶乘的实例代码
Aug 28 #Javascript
vue-router路由懒加载的实现(解决vue项目首次加载慢)
Aug 28 #Javascript
JS实现Cookie读、写、删除操作工具类示例
Aug 28 #Javascript
vue组件开发之用户无限添加自定义填写表单的方法
Aug 28 #Javascript
vue.js添加一些触摸事件以及安装fastclick的实例
Aug 28 #Javascript
You might like
一步一步学习PHP(2)――PHP类型
2010/02/15 PHP
PHP产生不重复随机数的5个方法总结
2014/11/12 PHP
php基于PDO连接MSSQL示例DEMO
2016/07/13 PHP
PHP性能分析工具xhprof的安装使用与注意事项
2017/12/19 PHP
基于jquery的bankInput银行卡账号格式化
2012/08/22 Javascript
收集json解析的四种方法分享
2014/01/17 Javascript
用Jquery选择器计算table中的某一列某一行的合计
2014/08/13 Javascript
JS实现的竖向折叠菜单代码
2015/10/21 Javascript
详解javascript实现瀑布流列式布局
2016/01/29 Javascript
js实现div模拟模态对话框展现URL内容
2016/05/27 Javascript
JavaScript中Form表单技术汇总(推荐)
2016/06/26 Javascript
整理一下常见的IE错误
2016/11/18 Javascript
本地Bootstrap文件字体图标引入却无法显示问题的解决方法
2020/04/18 Javascript
JS实现密码框的显示密码和隐藏密码功能示例
2016/12/26 Javascript
浅析vue深复制
2018/01/29 Javascript
基于angular6.0实现的一个组件懒加载功能示例
2018/04/12 Javascript
Angular模版驱动表单的使用总结
2018/05/05 Javascript
vue如何解决循环引用组件报错的问题
2018/09/22 Javascript
详解在vue-cli3.0中自定css、js和图片的打包路径
2019/08/26 Javascript
[02:12]Dota 2 推出全新英雄—— 电炎绝手
2019/08/23 DOTA
Python实现的数据结构与算法之基本搜索详解
2015/04/22 Python
python将秒数转化为时间格式的实例
2018/09/16 Python
Python使用到第三方库PyMuPDF图片与pdf相互转换
2019/05/03 Python
python源文件的字符编码知识点详解
2021/03/04 Python
HTML5不支持frameset的两种解决方法
2016/11/14 HTML / CSS
西班牙购买行李箱和背包网站:Maletas Greenwich
2019/10/08 全球购物
杭州SQL浙江浙大网新恩普软件有限公司
2013/07/27 面试题
C#如何调用Windows程序打开一个文档
2014/12/26 面试题
医院我们的节日活动实施方案
2014/08/22 职场文书
作风大整顿心得体会
2014/09/10 职场文书
2015年上半年党建工作总结
2015/03/30 职场文书
2015仓库保管员年终工作总结
2015/05/13 职场文书
2015年中秋晚会主持稿
2015/07/30 职场文书
2016教师节问候语
2015/11/10 职场文书
2019升学宴主持词范本5篇
2019/10/09 职场文书
Nginx如何限制IP访问只允许特定域名访问
2022/07/23 Servers