详解vue页面首次加载缓慢原因及解决方案


Posted in Javascript onNovember 06, 2019

第一次打包vue的项目部署到服务器下时,发现初次加载特别的缓慢,将近20s页面才加载出来,完全没有开发环境上的那么流畅。主要原因是页面在打包后如果不进行相关配置会导致资源文件特别的大,一次想要全部加载完成会特别的耗时。这里简单总结一下自己用到的一些优化的方案。

首先我们可以安装webpack-bundle-analyzer 插件,通过这个插件我们可以在打包的时候看到打包文件的大小,可以明显的看出哪些文件比较大。

解决方案一

1,去掉编译文件中map文件。在编译好后,我们会看到文件夹下有特别多的.map文件,这些文件主要是帮助我们线上调试代码,查看样式。所以为了避免部署包过大,通常都不生成这些文件。

在 config/index.js 文件中将productionSourceMap 的值设置为false. 再次打包就可以看到项目文件中已经没有map文件 (文件大小 35MB-->10.5MB)

2,vue-router 路由懒加载

懒加载即组件的延迟加载,通常vue的页面在运行后进入都会有一个默认的页面,而其他页面只有在点击后才需要加载出来。使用懒加载可以将页面中的资源划分为多份,从而减少第一次加载的时候耗时。

懒加载路由配置:

详解vue页面首次加载缓慢原因及解决方案

非懒加载路由配置:

详解vue页面首次加载缓慢原因及解决方案

如图所示为通过懒加载后打包的js文件。而非懒加载的打包后一般只有一个app.js 文件。

详解vue页面首次加载缓慢原因及解决方案

解决方案二

使用CDN减小代码体积加快请求速度

1. 为什么使用CDN

使用CDN主要解决两个问题:

  • 打包时间太长、打包后代码体积太大,请求慢
  • 服务器网络不稳带宽不高,使用cdn可以回避服务器带宽问题

2. 具体步骤

1.在/index.html中引入CDN

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title>vue-manage-system</title>
    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">

    <script src="https://cdn.bootcss.com/vue/2.5.3/vue.js"></script>
    <script src="https://cdn.bootcss.com/vue-router/2.7.0/vue-router.min.js"></script>
    <script src="https://cdn.bootcss.com/axios/0.17.1/axios.min.js"></script>
    <link rel="stylesheet" href="https://cdn.bootcss.com/element-ui/2.4.0/theme-chalk/index.css" rel="external nofollow" >
    <script src="https://cdn.bootcss.com/element-ui/2.4.0/index.js"></script>


  </head>
  <body>
    <div id="app"></div>
  </body>
</html>

注意:修改配置后还是提示Element未定义,是因为Element依赖Vue,vue.js需要在element-ui之前引入,所以vue.js也要改为cnd的引入方式.

2.修改/build/webpack.base.conf.js中修改配置。给module.exports添加externals属性(详见https://webpack.docschina.org/configuration/externals/),其中键是项目中引用的,值是所引用资源的名字。需要注意的是资源名需要查看所引用的JS源码,查看其中的全局变量是什么,例如element-ui的全局变量就说ELEMENT

module.exports = {
  context: path.resolve(__dirname, '../'),
  entry: {
   app: './src/main.js'
  },
  externals: {
   'vue': 'Vue',
   'vue-router': 'VueRouter',
   'ElementUI': 'ELEMENT',
   'axios': 'axios',
  }
 }

3.删除原先的import

如果不删除原先的import,项目还是会从node_modules中引入资源。
也就是说不删的话,npm run build时候仍会将引用的资源一起打包,生成文件会大不少。所以我认为还是删了好。

如:

详解vue页面首次加载缓慢原因及解决方案

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

Javascript 相关文章推荐
Iframe 自适应高度并实时监控高度变化的js代码
Oct 30 Javascript
javascript Onunload与Onbeforeunload使用小结
Dec 31 Javascript
鼠标经过显示二级菜单js特效
Aug 13 Javascript
JQuery分别取得每行最后一列和最后一行的示例代码
Aug 18 Javascript
怎么判断js脚本加载完成
Feb 28 Javascript
JavaScript设计模式之观察者模式(发布者-订阅者模式)
Sep 24 Javascript
jquery实现拖拽调整Div大小
Jan 30 Javascript
jQuery使用after()方法在元素后面添加多项内容的方法
Mar 26 Javascript
JS实现留言板功能[楼层效果展示]
Dec 27 Javascript
详解用vue2.x版本+adminLTE开源框架搭建后台应用模版
Mar 15 Javascript
Vue3 源码导读(推荐)
Oct 14 Javascript
JavaScript实现动态生成表格
Aug 02 Javascript
electron 安装,调试,打包的具体使用
Nov 06 #Javascript
weui中的picker使用js进行动态绑定数据问题
Nov 06 #Javascript
在vue中阻止浏览器后退的实例
Nov 06 #Javascript
vue 关闭浏览器窗口的时候,清空localStorage的数据示例
Nov 06 #Javascript
vue项目强制清除页面缓存的例子
Nov 06 #Javascript
关于vue路由缓存清除在main.js中的设置
Nov 06 #Javascript
JS实现随机抽取三人
Nov 06 #Javascript
You might like
PHP form 表单传参明细研究
2009/07/17 PHP
详解PHP中的Traits
2015/07/29 PHP
PHP模拟post提交数据方法汇总
2016/02/16 PHP
详解php与ethereum客户端交互
2018/04/28 PHP
PHP实现读取文件夹及批量重命名文件操作示例
2019/04/15 PHP
js实现页面打印功能实例代码(附去页眉页脚功能代码)
2009/12/15 Javascript
JS获取DropDownList的value值与text值的示例代码
2014/01/07 Javascript
JavaScript实现自动弹出窗口并自动关闭窗口的方法
2015/08/06 Javascript
JS实现图片平面旋转的方法
2016/03/01 Javascript
vue.js的提示组件
2017/03/02 Javascript
值得分享和收藏的xmlplus组件学习教程
2017/05/05 Javascript
js实现前端图片上传即时预览功能
2017/08/02 Javascript
详解Vuex管理登录状态
2017/11/13 Javascript
JavaScript伪数组用法实例分析
2017/12/22 Javascript
jQuery实现table表格checkbox全选的方法分析
2018/07/04 jQuery
使用webpack4编译并压缩ES6代码的方法示例
2019/04/24 Javascript
使用element-ui的el-menu导航选中后刷新页面保持当前选中状态
2019/07/19 Javascript
微信小程序实现动态列表项的顺序加载动画
2019/07/25 Javascript
mpvue 项目初始化及实现授权登录的实现方法
2020/07/20 Javascript
[50:21]Liquid vs Winstrike 2018国际邀请赛小组赛BO2 第二场
2018/08/19 DOTA
使用IPython来操作Docker容器的入门指引
2015/04/08 Python
python中星号变量的几种特殊用法
2016/09/07 Python
CentOS 7下安装Python 3.5并与Python2.7兼容并存详解
2017/07/07 Python
python决策树之CART分类回归树详解
2017/12/20 Python
对python中xlsx,csv以及json文件的相互转化方法详解
2018/12/25 Python
python实现websocket的客户端压力测试
2019/06/25 Python
pytorch 在sequential中使用view来reshape的例子
2019/08/20 Python
python retrying模块的使用方法详解
2019/09/25 Python
Python调用JavaScript代码的方法
2020/10/27 Python
Python虚拟环境virtualenv创建及使用过程图解
2020/12/08 Python
Pycharm 解决自动格式化冲突的设置操作
2021/01/15 Python
美国知名户外用品畅销中心:Sierra Trading Post
2016/07/19 全球购物
队名及霸气口号大全
2015/12/25 职场文书
医护人员继续教育学习心得体会
2016/01/19 职场文书
《赵州桥》教学反思
2016/02/17 职场文书
如何在Python项目中引入日志
2021/05/31 Python