直接上图

小程序应避免出现任何 JavaScript 异常

  • 出现 JavaScript 异常可能导致小程序的交互无法进行下去,我们应当追求零异常,保证小程序的高鲁棒性和高可用性

小程序所有请求应响应正常

  • 请求失败可能导致小程序的交互无法进行下去,应当保证所有请求都能成功

所有请求的耗时不应太久

  • 请求的耗时太长会让用户一直等待甚至离开,应当优化好服务器处理时间、减小回包大小,让请求快速响应

避免短时间内发起太多的图片请求

  • 短时间内发起太多图片请求会触发浏览器并行加载的限制,可能导致图片加载慢,用户一直处理等待。应该合理控制数量,可考虑使用雪碧图技术或在屏幕外的图片使用懒加载

避免短时间内发起太多的请求

  • 短时间内发起太多请求会触发小程序并行请求数量的限制,同时太多请求也可能导致加载慢等问题,应合理控制请求数量,甚至做请求的合并等

避免 setData 的数据过大

setData工作原理

  • 小程序的视图层目前使用 WebView 作为渲染载体,而逻辑层是由独立的 JavascriptCore
    作为运行环境。在架构上,WebView 和 JavascriptCore
    都是独立的模块,并不具备数据直接共享的通道。当前,视图层和逻辑层的数据传输,实际上通过两边提供的 evaluateJavascript
    所实现。即用户传输的数据,需要将其转换为字符串形式传递,同时把转换后的数据内容拼接成一份 JS 脚本,再通过执行 JS
    脚本的形式传递到两边独立环境。
  • 而 evaluateJavascript 的执行会受很多方面的影响,数据到达视图层并不是实时的。
  • 由于小程序运行逻辑线程与渲染线程之上,setData的调用会把数据从逻辑层传到渲染层,数据太大会增加通信时间

常见的 setData 操作错误

  • 频繁的去 setData
  • Android 下用户在滑动时会感觉到卡顿,操作反馈延迟严重,因为 JS
    线程一直在编译执行渲染,未能及时将用户操作事件传递到逻辑层,逻辑层亦无法及时将操作处理结果及时传递到视图层
  • 染有出现延时,由于 WebView 的 JS
    线程一直处于忙碌状态,逻辑层到页面层的通信耗时上升,视图层收到的数据消息时距离发出时间已经过去了几百毫秒,渲染的结果并不实时
  • 每次 setData 都传递大量新数据
  • 由setData的底层实现可知,数据传输实际是一次 evaluateJavascript
    脚本过程,当数据量过大时会增加脚本的编译执行时间,占用 WebView JS 线程
  • 后台态页面进行 setData
  • 当页面进入后台态(用户不可见),不应该继续去进行setData,后台态页面的渲染用户是无法感受的,另外后台态页面去setData也会抢占前台页面的执行

避免 setData 的调用过于频繁

  • setData接口的调用涉及逻辑层与渲染层间的线程通过,通信过于频繁可能导致处理队列阻塞,界面渲染不及时而导致卡顿,应避免无用的频繁调用

避免将未绑定在 WXML 的变量传入 setData

  • setData操作会引起框架处理一些渲染界面相关的工作,一个未绑定的变量意味着与界面渲染无关,传入setData会造成不必要的性能消耗

合理设置可点击元素的响应区域大小

  • 我们应该合理地设置好可点击元素的响应区域大小,如果过小会导致用户很难点中,体验很差

避免渲染界面的耗时过长

  • 渲染界面的耗时过长会让用户觉得卡顿,体验较差,出现这一情况时,需要校验下是否同时渲染的区域太大

避免执行脚本的耗时过长

  • 执行脚本的耗时过长会让用户觉得卡顿,体验较差,出现这一情况时,需要确认并优化脚本的逻辑

对网络请求做必要的缓存以避免多余的请求

  • 发起网络请求总会让用户等待,可能造成不好的体验,应尽量避免多余的请求,比如对同样的请求进行缓存

wxss 覆盖率较高,较少或没有引入未被使用的样式

  • 按需引入 wxss 资源,如果小程序中存在大量未使用的样式,会增加小程序包体积大小,从而在一定程度上影响加载速度

文字颜色与背景色搭配较好,适宜的颜色对比度更方便用户阅读

  • 文字颜色与背景色需要搭配得当,适宜的颜色对比度可以让用户更好地阅读,提升小程序的用户体验

所有资源请求都建议使用 HTTPS

  • 使用 HTTPS,可以让你的小程序更加安全,而 HTTP 是明文传输的,存在可能被篡改内容的风险

不使用废弃接口

  • 使用即将废弃或已废弃接口,可能导致小程序运行不正常。一般而言,接口不会立即去掉,但保险起见,建议不要使用,避免后续小程序突然运行异常

避免过大的 WXML 节点数目

  • 建议一个页面使用少于 1000 个 WXML 节点,节点树深度少于 30 层,子节点数不大于 60 个。一个太大的 WXML
    节点树会增加内存的使用,样式重排时间也会更长

避免将不可能被访问到的页面打包在小程序包里

  • 小程序的包大小会影响加载时间,应该尽量控制包体积大小,避免将不会被使用的文件打包进去

及时回收定时器

  • 定时器是全局的,并不是跟页面绑定的,当页面因后退被销毁时,定时器应注意手动回收

避免使用 css ':active' 伪类来实现点击态

  • 使用 css ':active' 伪类来实现点击态,很容易触发,并且滚动或滑动时点击态不会消失,体验较差
  • 建议使用小程序内置组件的 ‘hover-*’ 属性来实现

滚动区域可开启惯性滚动以增强体验

  • 惯性滚动会使滚动比较顺畅,在安卓下默认有惯性滚动,而在 iOS 下需要额外设置 -webkit-overflow-scrolling: touch 的样式

小程序性能和体验优化方法相关推荐

  1. 微信小程序开发04 性能优化:借助微信开发者工具提升小程序性能

    你好,我是周俊鹏. 前几节课我们分别从架构层(双线程模型).链路层(授权模型).和应用层(自定义组件)三个角度学习了小程序的技术要点.它们能帮你完成一个微信小程序的基本业务逻辑和交互逻辑. 逻辑的第一 ...

  2. 小程序性能优化之页面预加载方案——让你的小程序运行如飞 进阶篇

    小程序性能优化之页面预加载方案 进阶篇 转载请注明出处:https://blog.csdn.net/sinat_27612147/article/details/80798452 写在前面 预加载方案 ...

  3. 详解优化iOS程序性能的25个方法

    本篇文章主要介绍了优化iOS程序性能的25个方法,感兴趣的小伙伴们可以参考一下 1. 用ARC管理内存 ARC(Automatic ReferenceCounting, 自动引用计数)和iOS5一起发 ...

  4. 微信小程序性能优化技巧

    微信小程序如果想要优化性能,有关键性的两点:提高加载性能和提高渲染性能. 一.提高加载性能 当用户点击小程序后发生了什么? 资源准备(代码包下载) --  业务代码注入和渲染  --  异步请求数据 ...

  5. 小程序性能优化之页面预加载方案——让你的小程序运行如飞 集成篇

    小程序性能优化之页面预加载方案 集成篇 转载请注明出处:https://blog.csdn.net/sinat_27612147/article/details/80802725 前言 之前看到一篇文 ...

  6. 微信小程序性能优化方案

    文章目录 微信小程序性能优化方案 提高加载性能 小程序代码包准备(下载代码包) 开发者代码注入 页面渲染优化 提升渲染性能 setData工作原理 优化方法 微信小程序性能优化方案 微信小程序如果想要 ...

  7. 微信小程序性能优化之一

    微信小程序性能优化之一 原文:微信小程序性能优化之一 性能优化 界面和业务逻辑之间事件交互 小程序调用native Native回调小程序 图片源文件优化 渲染优化 ----------------- ...

  8. 改善WPF应用程序性能的10大方法(转)

    细数改善WPF应用程序性能的10大方法 2010年11月16日00:05 it168网站原创  作者:IT168 黄永兵  编辑:胡铭娅 评论:0条 本文Tag: ASP.NET WPF .NET   ...

  9. VMware vSphere 性能优化设计经验+优化方法 | 周末送资料

    VMware vSphere 性能优化设计经验+优化方法 | 周末送资料 https://mp.weixin.qq.com/s?__biz=MjM5NTk0MTM1Mw==&mid=26506 ...

  10. 性能测试实践|PerfDog助力微信小游戏/小程序性能调优

    概述 随着近年来微信生态圈的发展,小游戏,小程序也随之爆火,同样伴随着的便是对于小游戏/小程序的用户体验的严格要求:微信团队也在自家的微信平台推荐使用PerfDog测试小游戏/小程序的性能. 1.评测 ...

最新文章

  1. linux 操作系统级别监控 df 命令
  2. JS - Promise使用随笔
  3. 网站服务器被访问 io,服务器端被客户端访问完以后出现java.io.ioexception,socket问题。...
  4. HTML5 之 简单汇总
  5. 【转】Linux 下修改Tomcat使用的JVM内存大小
  6. 常用的前端跨域的几种方式
  7. 用户登录python_python用户登录系统
  8. 【LeetCode】【HOT 100】2. 两数相加
  9. android studio怎么输入中文,怎么在linux版的AndroidStudio输入中文?
  10. 解决tomcat启动startup.bat一闪而…
  11. Python:IPython性能度量
  12. RobotStudio关于Ctrl+鼠标左键拖动速度慢的解决方法
  13. FreeRTOS的HOOK,以及(23)FreeRTOS 空闲任务分析
  14. Tkinter打开一个新窗口后关闭前面的窗口
  15. python解释器需要另外安装吗_Python解释器安装
  16. 大功率H桥电机驱动板电路设计方案 此大功率直流电机驱动板采用ir2103驱动芯片
  17. JAVA生成随机昵称
  18. gradle优化之 总体配置优化
  19. 计算机每年学硕和专硕数量,重磅:2019年研究生招生数据报告,专硕报考人数超过学硕?...
  20. 霍兰德- 职业兴趣测评

热门文章

  1. 2022年2月沪牌拍牌出价策略
  2. 大数据技术如何影响企业决策?
  3. 10家不错的iphone编程资源站
  4. 入射波反射波和驻波的特性推导
  5. MayaDay1:历史记录和删除历史记录
  6. little endian c语言,endian.h这个头文件里面的宏可以直接用么?
  7. ADAS功能介绍 - ACC(一)
  8. 〔转载〕20条欠揍短消息
  9. Jenkins-构建项目
  10. 银河麒麟服务器修改ip,银河麒麟配置DNS服务器