详解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 相关文章推荐
jsp js鼠标移动到指定区域显示选项卡离开时隐藏示例
Jun 14 Javascript
基于Jquery+Ajax+Json实现分页显示附效果图
Jul 30 Javascript
JQuery设置时间段下拉选择实例
Dec 30 Javascript
js中的内部属性与delete操作符介绍
Aug 10 Javascript
JS简单实现城市二级联动选择插件的方法
Aug 19 Javascript
轻松实现Bootstrap图片轮播
Apr 20 Javascript
javascript+HTML5自定义元素播放焦点图动画
Feb 21 Javascript
Javascript 实现计算器时间功能详解及实例(二)
Jan 08 Javascript
angularjs中回车键触发某一事件的方法
Apr 24 Javascript
JS实现碰撞检测的方法分析
Jan 19 Javascript
Vue项目利用axios请求接口下载excel
Nov 17 Vue.js
微信小程序实现录音Record功能
May 09 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
实现WordPress主题侧边栏切换功能的PHP脚本详解
2015/12/14 PHP
php+laravel依赖注入知识点总结
2019/11/04 PHP
在 Laravel 6 中缓存数据库查询结果的方法
2019/12/11 PHP
用js得到网页中所有的div的id
2020/10/19 Javascript
初学Jquery插件制作 在SageCRM的查询屏幕隐藏部分行的功能
2011/12/26 Javascript
jQuery中hide()方法用法实例
2014/12/24 Javascript
jQuery使用post方法提交数据实例
2015/03/25 Javascript
详解JavaScript的Polymer框架中的通知交互
2015/07/29 Javascript
jQuery模拟物体自由落体运动(附演示与demo源码下载)
2016/01/21 Javascript
基于Jquery插件实现跨域异步上传文件功能
2016/04/26 Javascript
angularjs实现搜索的关键字在正文中高亮出来
2017/06/13 Javascript
一个简单的node.js界面实现方法
2018/06/01 Javascript
Echart折线图手柄触发事件示例详解
2018/12/16 Javascript
[58:29]DOTA2-DPC中国联赛 正赛 Phoenix vs XG BO3 第一场 1月31日
2021/03/11 DOTA
python从入门到精通(DAY 3)
2015/12/20 Python
使用python实现tcp自动重连
2017/07/02 Python
django上传图片并生成缩略图方法示例
2017/12/11 Python
Python爬虫框架Scrapy实例代码
2018/03/04 Python
python实现可视化动态CPU性能监控
2018/06/21 Python
python去重,一个由dict组成的list的去重示例
2019/01/21 Python
对python中if语句的真假判断实例详解
2019/02/18 Python
python中的数据结构比较
2019/05/13 Python
使用Python Pandas处理亿级数据的方法
2019/06/24 Python
keras模型保存为tensorflow的二进制模型方式
2020/05/25 Python
Python 实现PS滤镜中的径向模糊特效
2020/12/03 Python
HTML5边玩边学(3)像素和颜色
2010/09/21 HTML / CSS
mysql有关权限的表都有哪几个
2015/04/22 面试题
主管职责范文
2013/11/09 职场文书
活动倡议书范文
2014/05/13 职场文书
学校清明节活动总结
2014/07/04 职场文书
个人安全生产责任书
2014/07/28 职场文书
高中课前三分钟演讲稿
2014/08/18 职场文书
竞选班长演讲稿400字
2014/08/22 职场文书
项目备案申请报告
2015/05/15 职场文书
机关干部纪律作风整顿心得体会
2016/01/23 职场文书
vue前端工程的搭建
2021/03/31 Vue.js