单页应用首屏加载速度慢怎么解决?
1、什么是首屏加载时间?
首屏加载时间是指浏览器从相应用户输入网址到首屏内容渲染完成的时间,从用户的角度来说就是:“地址栏输入网址之后网页呈现的速度”。整个网站并不需要全部加载完成,但需要展示当前可视窗口中的内容。
2、如何计算首屏加载时间?
常用方法:
- 首屏模块标签标记法
- 统计首屏内加载最慢的图片的时间
- 自定义首屏内容计算法
- 借助第三方工具(pagespeed、vue-cli等等)
其实很简单,并不需要我们手动去计算。打开F12控制台,然后刷新网页,其中Load就是首屏加载时间。
3、首屏加载速度慢的原因
在页面渲染的过程,导致加载速度慢的因素可能如下
- 网络延时问题
- 资源文件体积是否过大问题
- 资源是否重复发送请求去加载问题
- 加载脚本的时候,渲染内容堵塞问题
4、解决方案
- 路由懒加载
以函数的形式加载路由,这样就可以把各自的路由文件分别打包,只有在解析给定路由的时候才会加载对应的路由组件。
- 静态资源本地缓存
前端合理使用localStorage,sessionStorage等缓存方式。 接口采用http缓存,合理设置cache-control等请求头。
- 图片压缩
像一些icon图标,我们并不需要在本地存放一张张的图片,可以用在线字体图标代替,或者将多个图标合并到一张图上,以减轻请求压力。
webpack处理图片常用依赖:
file-loader:在css 和html 主页中,相对路径的图片都会被处理,发布到输出目录中
url-loader:是对file-loader的封装,因此在安装了file-loader和url-loader 后,在webpack.config.js 中只对url-loader 做配置即可。url-loader的自身功能是给图片一个limit 标准,当图片小于limit时,使用base64 的格式引用图片;否则,使用url 路径引用图片。
image-webpack-loader:压缩图片。这个用得不算太多,因为前期可以直接让UI设计把图片压缩好,像ps 就可以自动的批量压缩图片。
- 减少重复请求
像一些表单提交或者长列表,合理使用防抖节流,以减少不必要的请求,减轻服务器压力。
- UI框架按需加载
借助 babel-plugin-component,我们可以只引入需要的组件,以达到减小项目体积的目的
- 开启GZip压缩
- 代码优化
1.v-if 和 v-show 的合理使用
2.使用v-for的时候为item设置唯一key值
3.细分vuejs组件
4.减少watch的数据
- 使用SSR服务端渲染
SSR(server side render),也就是服务端渲染,组件或页面通过服务器生成html字符串,再发送到浏览器。
SSR技术会实现将指定的异步数据在服务端渲染好,再返回给客户端,这样就减轻了客户端的请求异步数据的压力,渲染页面就更快了。
- vue可使用Nuxt.js框架实现服务端渲染
- react多采用koa2等技术的实现方案。
- 使用CDN
使用CDN主要解决两个问题:
① 打包时间太长、打包后代码体积太大、请求慢
② 服务器网络不稳定带宽不高,使用cdn刻意回避服务器贷款问题
单页应用首屏加载速度慢怎么解决?相关推荐
- vue单页应用首屏加载速度慢如何解决
首屏时间(First Contentful Paint),指的是浏览器从响应用户输入网址地址,到首屏内容渲染完成的时间. 一.加载慢的原因 在页面渲染的过程,导致加载速度慢的因素可能如下: 网络延时问 ...
- 浅谈Vue单页应用首屏加载速度优化方案
心语:最不会利用时间的人,最会抱怨时间不够 趁着五一放假,刚好最近天气也是不好,.所以抽出一点时间写一点东西,也算是不辜负这个美好的假期吧!小编也祝愿大家五一快乐,玩得愉快哈 随着各大前端框架的诞生以 ...
- VUE单页应用首屏加载速度优化方案
单页应用会随着项目越大,导致首屏加载速度很慢!!!以下给出在下知道的几种优化方案 使用CDN资源,减小服务器带宽压力 路由懒加载 将一些静态js css放到其他地方(如OSS),减小服务器压力 按需加 ...
- SPA单页面应用首屏加载速度提升方法
SPA单页面应用首屏加载速度提升方法 首屏加载 计算首屏加载时间公式 解决方法 减少入口文件体积 静态资源本地缓存 UI框架按需加载 避免组件重复打包 图片资源压缩 开启GZip压缩 首屏加载 首屏加 ...
- 单页应用的优缺点,单页应用首屏加载优化、小程序首次启动速度优化
单页应用的优缺点 单页应用,简称(Single Page Application)是指整个应用只一个HTML页面,所有的功能和交互都在这个页面完成,利用JavaScript动态改变HTML内容. 优点 ...
- 面试官:SPA(单页应用)首屏加载速度慢怎么解决?
故心故心故心故心小故冲啊 文章目录 一.什么是首屏加载 二.加载慢的原因 三.解决方案 小结: 参考文献 一.什么是首屏加载 首屏时间(First Contentful Paint),指的是浏览器从响 ...
- SPA(单页应用)首屏加载慢的优化方案
一. 什么是首屏加载时间? 首屏加载时间是指浏览器从相应用户输入网址到首屏内容渲染完成的时间. 整个网站并不需要全部加载完成,但需要展示当前可视窗口中的内容,也就是首屏. 从用户的角度来说就是:&qu ...
- 面试官:首屏加载速度慢怎么解决?
文章目录 前言 首屏加载时间的计算 首屏的定义 首屏加载过程 计算首屏时间 加载慢的原因 面试中常涉及的解决方案 减小入口文件体积 懒加载 减小文件大小 静态资源本地缓存 UI框架按需加载 组件重复打 ...
- SPA首屏加载速度慢怎么解决?
一.什么是首屏加载? 首屏时间,指的是浏览器从响应用户输入网址地址,到首屏内容渲染完成的时间,此时整个网页不一定要全部渲染完成,但需要展示当前视窗需要的内容.首屏加载可以说是用户体验中最重要的环节. ...
最新文章
- android 安装sqlite3,Android真机安装sqlite3的方法
- 5.5.3 per-connection time zone support
- linux c 服务程序,Linux C 后台服务程序单进程控制
- Java zset 应用_Java简单使用redis-zset实现排行榜
- postman 使用_Postman使用方法
- 路由复用器--gorilla/mux
- 8位并行左移串行转换电路_74ls194串行数据到并行数据的转换
- PDMS开发使用的pml界面设计器
- 传奇服务器玩家信息备份,传奇:史上5大漏洞,损失惨重,盛大被迫将服务器回档2天...
- (转)【JSON工具】一个JSON格式化查看工具——HIJSON
- python3.5安装PyHook3
- GTX1060 Windows7/Windows8/Windows8.1 旧版显卡驱动下载链接
- Photoshop选区选取详解
- 【车牌识别】基于模板匹配实现车牌识别含Matlab源码
- C++基础知识 - 多重继承的二义性问题
- OCT病灶分割论文泛读
- scala的两种变量类型 var 和 val
- 大A股票主力对敲倒量,接盘返点有哪些特征
- Towards 3D Human Pose Estimation in the Wild: a Weakly-supervised Approach论文翻译
- 图解央行房贷新政 首付才是刚需族最大门槛