如何提高Vue项目首页的加载速度

开发 前端
为何当一个VUE项目过大时,打包之后初次访问首页加载速度会异常的缓慢,是什么原因导致以及如何解决这些问题?

 为何当一个VUE项目过大时,打包之后初次访问首页加载速度会异常的缓慢,是什么原因导致以及如何解决这些问题?

[[277681]]

 

首页打开速度慢的原因

其实浏览器加载一个页面的过程就是通过http协议从服务器端下载项目所需要的资源,将html js 图片文件下载到本地解析后显示出来,如果出现网页加载速度慢,打不开无非以下几个原因:

  1. 程序自身的Bug导致页面加载异常
  2. 项目的资源太大(如果js 大的图片)导致访问浏览器从服务器获取的所需资源的时间较长
  3. 网速慢等

所以当我们的项目出现这种问题时只要F12开启浏览器的控制台看下network中请求资源的耗时即可找出问题,通过观察,现在前端的单页面应用都是是靠 js 生成,因为是spa,而且所有的渲染都在脚本上,js执行需要时间。另外加载js也要时间,所以页面越大,加载时间越长,而且js执行的时间也长,所以会出现白屏的情况。

如何解决这个问题

导致这个问题的原因就是我们项目打包后资源太大导致,所以我们可以尽量的减少优化打包后文件的大小,这样问题便迎刃而解,怎么去优化通常有以下几点:

利用路由的懒加载实现组件的按需加载,这样配置后只有当路由被访问时才会加载对应的组件,而不是在加载首页的时候就直接加载。

  1. {  
  2.  path: "/usercenter/personal"
  3.  title: "个人信息"
  4.  component: resolve => { 
  5.    require(["@/views/usercenter/personal.vue"], resolve); //通过requie动态加载即可 
  6.       } 
  7.    }, 

异步加载组件

 

既然是异步加载,就会存在加载失败等异常情况。这时候怎么办呢?看官网绐出的另一个特性

 

这样就可以完美的解决我们的疑问了,当异步组件加载失败后会显示错误的组件。

1. 禁用线上生成的map文件

npm run build编译之后,我们查看编译生成的文件,发现有很多.map文件,这些文件也占了不小的空间。.map文件的作用是帮助编译后的代码调试,但是我们上线的代码已经调试完成,所以上线时可以不生成.map文件。

  1. productionSourceMap:  
  2. false  //配置webpack中productionSourceMap值为false即可 

2. 启用Nginx的gzip压缩功能

在nginx.conf中的http{ }中添加如下代码即可:

  1. gzip on
  2. gzip_disable "msie6"
  3. gzip_vary on
  4. gzip_proxied any
  5. gzip_comp_level 1; 
  6. gzip_buffers 16 8k; 
  7. gzip_http_version 1.0; 
  8. gzip_min_length 256; 
  9. gzip_types text/plain text/css 
  10.     application/jsonapplication/x-javascript text/xml 
  11.     application/xmlapplication/xml+rss text/javascript 
  12.     application/vnd.ms-fontobjectapplication/x-font-ttf font/opentype   
  13.  image/svg+xml image/x-icon 
  14.  image/jpeg image/gifimage/png; 

配置好后重启服务重新访问网站在控制台中查看是否生效

 

3. 对于一些通用的工具库可以采用CDN引入,如Jquery,在index.html中从CDN引入,去掉其他页面的组件import,修改webpack.base.config.js,在externals中加入该组件即可。

4. 服务器端SSR渲染。 SSR需要在页面架构做一些对应的调整,稍微复杂,具体可参考https://segmentfault.com/a/1190000015964813。

5. 代码层面的优化,精灵图,组件化模块化,优化代码逻辑,提高代码复用性等。

责任编辑:武晓燕 来源: 新钛云服
相关推荐

2010-12-24 08:57:44

Google加速工具page-speed

2011-06-09 16:14:14

2011-05-30 13:28:00

PHP

2016-09-07 15:02:03

ElasticSear索引速度

2009-03-18 09:06:00

GoogleChrome浏览器

2017-10-20 10:09:01

代码CocoaPods编译

2021-01-08 09:40:40

优化VUE性能

2011-05-19 11:33:38

数据库访问速度

2009-10-16 08:48:08

2022-04-27 09:24:22

前端代码速度

2011-07-04 17:45:45

Qt Sqlite 数据库

2010-03-12 15:49:46

Python字串查找

2009-03-30 14:12:38

LinuxUnladenSwallow

2016-03-02 17:55:03

app用户加载

2021-05-12 11:19:08

DevTools堆栈追踪

2020-05-26 13:25:00

语言编译代码

2011-05-30 13:15:05

PHP

2010-01-06 16:55:33

Web交换机

2011-05-27 14:25:04

网页加载时间

2009-06-24 15:16:19

AJAX客户端
点赞
收藏

51CTO技术栈公众号