导致页面加载白屏时间长的原因有哪些,怎么进行优化?

6 篇文章 0 订阅
4 篇文章 0 订阅

一、白屏时间

白屏时间:即用户点击一个链接或打开浏览器输入URL地址后,从屏幕空白到显示第一个画面的时间。

二、白屏时间的重要性

当用户点开一个链接或者是直接在浏览器中输入URL开始进行访问时,就开始等待页面的展示。页面渲染的时间越短,用户等待的时间就越短,用户感知到页面的速度就越快。这样可以极大的提升用户的体验,减少用户的跳出,提升页面的留存率。

三、白屏的过程

从输入url,到页面的画面展示的过程

1、首先,在浏览器地址栏中输入url

2、浏览器先查看浏览器缓存-系统缓存-路由器缓存,如果缓存中有,会直接在屏幕中显示页面内容。若没有,则跳到第三步操作。

3、在发送http请求前,需要域名解析(DNS解析),解析获取相应的IP地址。

4、浏览器向服务器发起tcp连接,与浏览器建立tcp三次握手。

5、握手成功后,浏览器向服务器发送http请求,请求数据包。

6、服务器处理收到的请求,将数据返回至浏览器

7、浏览器收到HTTP响应

8、读取页面内容,浏览器渲染,解析html源码

9、生成Dom树、解析css样式、js交互,渲染显示页面

浏览器下载HTML后,首先解析头部代码,进行样式表下载,然后继续向下解析HTML代码,构建DOM树,同时进行样式下载。当DOM树构建完成后,立即开始构造CSSOM树。理想情况下,样式表下载速度够快,DOM树和CSSOM树进入一个并行的过程,当两棵树构建完毕,构建渲染树,然后进行绘制。

Tips:浏览器安全解析策略对解析HTML造成的影响:

当解析HTML时遇到内联JS代码,会阻塞DOM树的构建,会先执行完JS代码;当CSS样式文件没有下载完成时,浏览器解析HTML遇到了内联JS代码,此时,浏览器暂停JS脚本执行,暂停HTML解析。直到CSS文件下载完成,完成CSSOM树构建,重新恢复原来的解析。

JavaScript 会阻塞 DOM 生成,而样式文件又会阻塞 JavaScript 的执行,所以在实际的工程中需要重点关注 JavaScript 文件和样式表文件,使用不当会影响到页面性能的。

四、白屏-性能优化

1. DNS解析优化

针对DNS Lookup环节,我们可以针对性的进行DNS解析优化。

  • DNS缓存优化
  • DNS预加载策略
  • 稳定可靠的DNS服务器

2. TCP网络链路优化

通过服务器进行优化,一般都需要花钱!

3. 服务端处理优化

服务端的处理优化,是一个非常庞大的话题,会涉及到如Redis缓存、数据库存储优化或是系统内的各种中间件以及Gzip压缩等…

4. 浏览器下载、解析、渲染页面优化

根据浏览器对页面的下载、解析、渲染过程,可以考虑一下的优化处理:

  • 尽可能的精简HTML的代码和结构
  • 尽可能的优化CSS文件和结构
  • 一定要合理的放置JS代码,尽量不要使用内联的JS代码
  • 将渲染首屏内容所需的关键CSS内联到HTML中,能使CSS更快速地下载。在HTML下载完成之后就能渲染了,页面渲染的时间提前,从而缩短首屏渲染时间;
  • 延迟首屏不需要的图片加载,而优先加载首屏所需图片(offsetTop<clientHeight)
document.documentElement.clientHeight//获取屏幕可视区域的高度
element.offsetTop//获取元素相对于文档顶部的高度

 因为JavaScript 会阻塞 DOM 生成,而样式文件又会阻塞 JavaScript 的执行,所以在实际的工程中需要重点关注 JavaScript 文件和样式表文件,使用不当会影响到页面性能的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 白屏时间是指用户在打开网页后,直到看到页面内容之间的时间间隔。要减少白屏时间,可以采用以下方法:1.减少图像文件的大小;2.使用 CDN 加速;3.优化 JavaScript 和 CSS 代码;4.使用浏览器缓存;5.对网页进行加载等。 ### 回答2: 前端性能优化是指通过一系列的调整和优化,提高网页的加载速度和响应速度,提升用户体验。其中减少白屏时间是一项重要的优化目标。 白屏时间是指页面打开后用户看到内容的时间间隔。通常情况下,用户打开页面后,由于网络请求、资源加载原因,会有一段时间页面处于空白状态,这段时间即为白屏时间。减少白屏时间可以提升用户的感知速度,使用户更快地看到页面内容。 减少白屏时间的方法有以下几种: 1. 减少页面加载时间:通过优化页面结构、合理使用CSS和JavaScript等前端技术,减少页面的大小和请求个数,从而加快页面加载速度。 2. 预加载关键资源:提前加载页面需要的关键资源,比如CSS、JavaScript、图片等,可以通过使用预加载的方式,使这些资源在页面打开前就开始加载,从而减少白屏时间。 3. 使用缓存:利用浏览器的缓存机制,将页面需要的静态资源缓存到本地,下次访问时可以直接从缓存中获取,减少网络请求的时间。 4. 懒加载:仅加载当前可见区域内的内容,延迟加载其他内容,在用户滚动页面时再加载。这样可以减少页面首次加载的资源量,提高页面加载速度。 5. 提前获取数据:如果页面需要从后端获取数据,可以在页面加载时就开始请求数据,然后在渲染页面时直接使用已获取的数据,减少用户等待数据响应的时间,缩短白屏时间。 综上所述,通过适当的优化措施,可以有效减少白屏时间,提升前端性能,提高用户体验。 ### 回答3: 前端性能优化是指通过各种方法和技术来提高网页加载和交互的速度和效率,其中之一就是减少白屏时间白屏时间是指用户在打开网页时,页面内容出现之前的等待时间。在这个过程中,用户会感觉到页面没有任何反应,导致用户体验下降。 为了减少白屏时间,我们可以采取以下几种策略: 1. 压缩和合并资源文件:将CSS和JavaScript文件进行压缩和合并,减少HTTP请求和传输时间,从而提高加载速度。 2. 使用浏览器缓存:合理设置缓存策略,使相同的资源可以从缓存中获取,避免重复请求,减少加载时间。 3. 异步加载资源:将非关键资源(如广告、统计代码等)的加载放在页面内容加载完毕后进行,以保证页面内容的快速呈现。 4. 延迟加载图片:将页面上的图片设置为延迟加载,只有在用户滚动到可见范围时才进行加载,避免一次性请求过多的图片,提高加载速度。 5. 使用CDN加速:将静态资源部署到全球各地的CDN节点上,利用就近访问的优势,减少网络延迟,加快资源加载速度。 6. 懒加载:只加载当前可见区域的内容,将其他内容延迟加载,延迟加载可以提高页面加载速度,减少白屏时间。 7. 优化首屏渲染:将关键资源和内容放在页面的最前面,提高首屏的加载速度,使用户能够更快地看到页面内容。 通过以上的优化策略,可以有效地减少白屏时间,提高网页的加载速度和用户的体验。但需要注意的是,在优化的过程中,要综合考虑兼容性、用户体验等因素,避免影响网页的功能和可用性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值