详解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 相关文章推荐
js中几种去掉字串左右空格的方法
Dec 25 Javascript
[IE&amp;FireFox兼容]JS对select操作
Jan 07 Javascript
JavaScript 异步调用框架 (Part 1 - 问题 &amp; 场景)
Aug 03 Javascript
AngularJS实现表单验证
Jan 28 Javascript
js树插件zTree获取所有选中节点数据的方法
Jan 28 Javascript
JS鼠标拖拽实例分析
Nov 23 Javascript
javascript日期比较方法实例分析
Jun 17 Javascript
JS模拟bootstrap下拉菜单效果实例
Jun 17 Javascript
vue+vue-validator 表单验证功能的实现代码
Nov 13 Javascript
基于vue-cli vue-router搭建底部导航栏移动前端项目
Feb 28 Javascript
javascript将16进制的字符串转换为10进制整数hex
Mar 05 Javascript
JS实现网页时钟特效
Mar 25 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-fpm配置详解
2014/02/12 PHP
laravel实现分页样式替换示例代码(增加首、尾页)
2017/09/22 PHP
Yii2框架自定义类统一处理url操作示例
2019/05/25 PHP
Laravel关系模型指定条件查询方法
2019/10/10 PHP
JavaScript读取中文cookie时的乱码问题的解决方法
2009/10/14 Javascript
JavaScript DOM学习第四章 getElementByTagNames
2010/02/19 Javascript
jquery Mobile入门—多页面切换示例学习
2013/01/08 Javascript
详细介绍8款超实用JavaScript框架
2013/10/25 Javascript
以JSON形式将JS中Array对象数组传至后台的方法
2014/01/06 Javascript
js中settimeout方法加参数
2014/02/28 Javascript
jquery实现搜索框常见效果的方法
2015/01/22 Javascript
JS+CSS模拟可以无刷新显示内容的留言板实例
2015/03/03 Javascript
JavaScript编写简单的计算器
2015/11/25 Javascript
特殊日期提示功能的实现方法
2016/06/16 Javascript
使用Bootstrap美化按钮实例代码(demo)
2017/02/03 Javascript
jQuery实现手势解锁密码特效
2017/08/14 jQuery
详解开源的JavaScript插件化框架MinimaJS
2017/10/26 Javascript
详解使用React全家桶搭建一个后台管理系统
2017/11/04 Javascript
HTML5+JS+JQuery+ECharts实现异步加载问题
2017/12/16 jQuery
.vue文件 加scoped 样式不起作用的解决方法
2018/05/28 Javascript
解决vue.js this.$router.push无效的问题
2018/09/03 Javascript
html中创建并调用vue组件的几种方法汇总
2020/11/17 Javascript
python进程和线程用法知识点总结
2019/05/28 Python
Django集成celery发送异步邮件实例
2019/12/17 Python
Python Scrapy框架第一个入门程序示例
2020/02/05 Python
美国豪华时尚女性精品店:Kirna Zabête
2018/01/11 全球购物
英国第一职业高尔夫商店:Clickgolf.co.uk
2020/11/18 全球购物
Vuori官网:运动服装的终级表现
2021/01/27 全球购物
Belvilla法国:休闲度假房屋出租
2020/10/03 全球购物
项目资料员岗位职责
2013/12/10 职场文书
宣传保护环境的公益广告词
2014/03/13 职场文书
募捐倡议书
2014/04/14 职场文书
活动新闻稿范文
2015/07/17 职场文书
幼儿园小朋友毕业感言
2015/07/30 职场文书
nginx前后端同域名配置的方法实现
2021/03/31 Servers
React四级菜单的实现
2022/04/08 Javascript