为什么会首屏白屏

为什么会首屏白屏

浏览器渲染包含 HTML 解析、DOM 树构建、CSSOM 构建、JavaScript 解析、布局、绘制等等,大致如下图所示:

 

要搞清楚为什么会有白屏,就需要利用这个理论基础来对实际项目进行具体分析。通过 DevTools 进行分析:

 

  • 等待 HTML 文档返回,此时处于白屏状态。
  • 对 HTML 文档解析完成后进行首屏渲染,因为项目中对加了灰色的背景色,因此呈现出灰屏。
  • 进行文件加载、JS 解析等过程,导致界面长时间出于灰屏中。
  • 当 Vue 实例触发了 mounted 后,界面显示出大体框架。
  • 调用 API 获取到时机业务数据后才能展示出最终的页面内容。

由此得出结论,因为要等待文件加载、CSSOM 构建、JS 解析等过程,而这些过程比较耗时,导致用户会长时间出于不可交互的首屏灰白屏状态,从而给用户一种网页很“慢”的感觉。那么一个网页太“慢”,会造成什么影响呢?

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
uniapp是一款基于Vue.js开发的跨平台应用框架。在开发uniapp应用时,常常会遇到屏白屏的问题,即应用打开时,页面呈现空白的状态。下面我将介绍一些解决屏白屏问题的方法。 先,我们可以尝试使用uniapp提供的异步加载组件的功能,将一些页面布局复杂、渲染耗时较长的组件从屏加载中剔除,以提高屏加载速度。可以通过App.vue中的globalStyle全局样式来控制屏加载的样式,比如设置一个占位容器,等异步组件加载完成后再显示真正的内容。 其次,我们还可以使用uniapp中提供的分包加载功能,将一些不必要的组件或页面放到其他分包中,在屏加载时不进行载入,只有在需要使用时才进行下载。这样可以大大减少屏加载的负担,提高屏渲染速度。 另外,我们可以在manifest.json文件中设置页面的优先级,将屏需要加载的页面设置为较高的优先级,保证屏的加载顺序。可以通过设置"navigationStyle"为"custom",并在页面的onLoad中手动调用uniapp的渲染函数来控制屏页面的加载。 还可以利用uniapp提供的预渲染功能,通过预先生成静态页面,在用户访问时直接展示已经生成好的页面,从而避免了屏白屏的问题。 最后,我们还可以通过优化代码、图片压缩、减少请求等手段来提高屏加载速度,从而避免屏白屏问题的发生。 以上是一些解决uniapp屏白屏问题的方法,希望对您有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值