创新互联百度小程序教程:白屏优化建议

  • 白屏优化建议
    • 白屏检测说明
    • 白屏优化
      • 排查异常
        • 服务稳定性
        • 业务逻辑
        • 框架兼容性
      • 优化性能和体验

    白屏优化建议

    白屏检测说明

    白屏定义:用户触发页面打开后,间隔一定时间后仍然没有任何页面绘制,则认定为白屏。

    成都创新互联公司专业成都网站设计、做网站,集网站策划、网站设计、网站制作于一体,网站seo、网站优化、网站营销、软文平台等专业人才根据搜索规律编程设计,让网站在运行后,在搜索中有好的表现,专业设计制作为您带来效益的网站!让网站建设为您创造效益。

    白屏检测原理:从用户点击小程序入口开始计算时间,6s 后进行截图分析。当截图为空白页面或只有背景色,则记为一次白屏。

    白屏监控范围:仅针对小程序进入时的首个页面进行检测。

    数据解读:白屏率 = 白屏发生 PV / 小程序冷启动打开 PV,开发者可以在小程序平台上看到自己小程序白屏率的数据情况。在上述检测机制下,无论小程序启动时出现异常还是页面加载过程较慢,6S 时被监测到无内容展示,都会视为白屏。因此在进行白屏优化时,需要从两方面着手,一方面对页面异常问题进行排查,另一方面着重优化页面的性能。

    白屏优化

    排查异常

    小程序白屏数据出现异常上涨时,可以从以下三个方面着手排查分析:

    服务稳定性

    1. 小程序页面数据请求是否正常:
      通过线上巡检,发现有小程序存在自身服务不稳定的情况。例如小程序页面数据请求返回 4XX,5XX 错误等。
    2. HTTPS 证书是否存在问题:
      排查 HTTPS 证书是否已过期,导致小程序相关请求失败,无法展示数据。
      有些小程序可能误使用了自签的 HTTPS 证书,由于无法被信任,用户也无法强制信任,导致页面数据获取失败。

    业务逻辑

    有些小程序的页面数据展示可能存在前置条件,例如需要登录、定位等。在条件不满足时,可能存在兼容处理问题。这里给出常见的几种 case:

    1. 页面打开时需要首先进行授权,获取权限:
      授权失败时需要有响应的兼容逻辑或者给予明确提示。
    2. 页面打开时需要登录才可展示内容:
      例如常见的购物类小程序,用户未登录时需要有相应的提示,以及触发登录的按钮或者入口。
    3. 网络连接失败时,页面兼容性不足:
      这种情况最好是有对应的错误页和重试入口,保证用户可再操作,提供自主恢复的能力。
    4. 逻辑中存在自设校验,校验不通过:
      有些小程序是从微信小程序迁移而来,内部逻辑中可能存在自设的平台检测校验等,迁移时或者版本更新时没有同步变更,导致校验不通过,从而导致页面异常。

    框架兼容性

    小程序框架自身也在不断更新,所支持的能力也在不断更新和扩充。同样,开发者也会对小程序自身也会进行版本更新。这里就涉及到了兼容性问题。小程序框架版本修复 Bug 记录和版本兼容性,请参考以下连接了解和主动规避:

    1. 语法支持性:运行环境
    2. 版本兼容性:兼容性说明
    3. 框架更新日志及修复问题说明:历史更新日志

    优化性能和体验

    已有启动性能数据,平均数据和 80 分位数据较快不一定能保证白屏率就低,白屏 case 大概率发生在性能的长尾数据中。
    从平台跟进的多个小程序白屏数据分析结果来看,小程序白屏率高的主要因素是页面数据加载和渲染较慢。如果小程序上线后白屏数据就处于高位,或者版本更新后白屏数据上涨,可以通过以下方面进行分析和优化:

    1. 页面结构:

    部分小程序的页面内容重度依赖于服务器的返回,在服务端没有数据返回的时候,页面没有任何内容展示,这样的情况在遇到网络波动或者服务发生抖动的时候会造成白屏率的陡增。开发者可以在服务端数据返回之前通过动画,文案体验上的优化来减小白屏率。
    2. 页面数据加载方式:

    针对一次请求返回的数据过多的情况,可以从两个角度来优化:1. 非关键数据延迟请求;2. 非关键数据延迟渲染。

    非关键数据延迟请求:

     
     
     
    1. swan.request({
    2. url: 'https://www.baidu.com/keyData',
    3. success: res => {
    4. this.setData({
    5. keyData: res
    6. });
    7. swan.request({
    8. url: 'https://www.baidu.com/nonKeyData',
    9. success: res => {}
    10. });
    11. }
    12. });

    非关键数据延迟渲染:

     
     
     
    1. this.setData({keyData}, () => {
    2. this.setData({nonKeyData});
    3. });
    1. 增加过渡态提示

    页面加载时,可以使用 Loading 组件等形式进行提示,给用户一个提示,提升用户体验。

    1. 使用骨架屏

    骨架屏形式类似下图,可以很好的提升用户使用小程序时的体验。

    1. 默认态处理
      例如在涉及到定位时,部分小程序会等待定位完成后才展示数据,可以增加默认态数据或当前城市缓存,定位完成后再更新页面数据。

    本文标题:创新互联百度小程序教程:白屏优化建议
    标题网址:http://www.csdahua.cn/qtweb/news9/540959.html

    网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

    广告

    声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网