iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >小程序redux性能优化的方法
  • 659
分享到

小程序redux性能优化的方法

2023-06-26 08:06:39 659人浏览 安东尼
摘要

这篇文章主要介绍“小程序redux性能优化的方法”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“小程序redux性能优化的方法”文章能帮助大家解决问题。首先了解小程序的工作原理和性能关键点。1工作原理

这篇文章主要介绍“小程序redux性能优化的方法”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“小程序redux性能优化的方法”文章能帮助大家解决问题。

首先了解小程序的工作原理和性能关键点。

1工作原理 (官方说明)

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

2性能关键点(官方说明)

  1. 频繁的去 setData 
    在我们分析过的一些案例里,部分小程序会非常频繁(毫秒级)的去setData,其导致了两个后果:

Android 下用户在滑动时会感觉到卡顿,操作反馈延迟严重,因为 JS 线程一直在编译执行渲染,未能及时将用户操作事件传递到逻辑层,逻辑层亦无法及时将操作处理结果及时传递到视图层; 
渲染有出现延时,由于 WebView 的 JS 线程一直处于忙碌状态,逻辑层到页面层的通信耗时上升,视图层收到的数据消息时距离发出时间已经过去了几百毫秒,渲染的结果并不实时;

  1. 每次 setData 都传递大量新数据 
    由setData的底层实现可知,我们的数据传输实际是一次 evaluateJavascript 脚本过程,当数据量过大时会增加脚本的编译执行时间,占用 WebView JS 线程,

  2. 后台态页面进行 setData 
    当页面进入后台态(用户不可见),不应该继续去进行setData,后台态页面的渲染用户是无法感受的,另外后台态页面去setData也会抢占前台页面的执行。

3度量性能指标

我们在优化性能时,指标是非常重要的,没有指标,你没法知道优化的点是否有效。不能单凭感觉去优化,要根据指标反馈,明确优化的成果。同时,优化就像个无底洞,要注意投入产出比。 
用户反馈的卡顿,要么就是js执行消耗资源过多导致处理器没响应,要么是UI渲染消耗资源过多,导致UI没法响应用户操作。 
通过查看代码,我们并没有消耗大量计算资源的业务逻辑,但是出现了UI反复操作和抢占资源的现象。

4如何度量

可以利用setData的第二个参数,传入callback函数,统计渲染时长。代码如下

let startTime = Date.now()this.setData(data, () => {let endTime = Data.now()console.log(endTime - startTime, '渲染时长')})

案例分析  1、检查点:是否频繁去setData  检查结果:存在  产生原因:redux中监听的是整个store,只要store变化,就会执行setData操作,这就意味着页面无关的数据改变,也会触发该页面执行setData操作,但是这个操作是无意义的。  问题代码:

// libs/redux-wechat/connect.js // 对整个store进行subscribe。变化就执行handleChangethis.unsubscribe = this.store.subscribe(handleChange.bind(this, options)); function handleChange(options) {...省略代码const state = this.store.getState()const mappedState = mapState(state, options);this.setData(mappedState)}

解决方案:

只监听当前页面用到的store中的部分数据,只有该部分数据变化,才setData。(store没提供单个数据的监听,如果自己修改redux实现,难度较大,同时修改太底层,容易出不可预料的异常。)  判断页面数据与需要更新数据是否相同,如果相同,不做操作。(这个方案成本比较低,就用它吧)

代码实现:

// libs/redux-wechat/connect.js// 如果更新的数据和页面数据相同,不做操作。function handleChange(options) {...省略代码const state = this.store.getState()const mappedState = mapState(state, options);// 如果更新的数据和页面数据相同,不做操作。if (mappedState === this.prevState) return // 新加入代码this.setData(mappedState)// 保存上一次数据this.prevState = mappedState // 新加入代码}

另外一个优化:如果store数据毫秒级变化怎么办,例如更新购物车的同时,还更新了购物数量,能不能把两次变化合并起来?因为store的数据是共享的,最后一次的更新就是最新的数据,可以采用节流器对请求进行合并。

clearTimeout(this.setDataTMO)this.setDataTMO = setTimeout(() => {this.setData(mappedState)}, 50); // 时间可以看情况调整

2、检查点:每次 setData 都传递大量新数据  检查结果:存在  产生原因:

页面存在引用没用到的store数据。  后端返回数据直接进入store,后端接口返回冗余字段。

问题代码:

/pages/user/index.jsconnect(state => ({member: state.member,mycoupon: state.mycoupon,guessLikeList: state.recommend.guessLikeList,locationInfo: state.common && state.common.locationInfo, //可删除selectedseller: state.home.selectedseller,//可删除carts: state.carts.carts,//可删除...state.common}))

解决方案:

删除页面无用的connect (老业务在使用,修改存在风险,通过后续迭代优化)  请求后端接口后,拿到数据进行优化处理再把数据传入store(成本较高)

3、检查点:后台态页面进行 setData  检查结果:存在  产生原因:redux connect设计与小程序有差异  问题代码:

// libs/redux-wechat/connect.jsfunction onLoad(options) {...省略部分代码if(shouldSubscribe){this.unsubscribe = this.store.subscribe(handleChange.bind(this, options));handleChange.call(this, options)}}function onUnload() {...省略部分代码// 页面onUnload时,才解除监听typeof this.unsubscribe === 'function' && this.unsubscribe()}

小程序生命周期中,onUnload会在页面销毁时执行,例如A->B->C->D 的跳转,A页面一直在监听store的变化,如果D页面修改数据,会造成A,B,C页面也执行setData操作,抢占了D的资源,因此造成卡顿。  解决方案:

后台状态的页面在setData时直接return(目前采用该方法)  当页面隐藏时,移除监听。

代码实现:

// 因为在后台的页面setData会抢占前台资源,所以在后台的页面不要执行setData操作if (this.route !== _getActivePage().route) return

但是由于在后台的页面数据没法更新,如果D页面修改A引用的数据,就会出现A引用旧数据问题,所以在onShow的时候做一次同步。

// 后台的页面切换到前台的时候,做一次数据同步function onShow(options) {if(shouldSubscribe){handleChange.call(this, options)}if (typeof _onShow === 'function') {_onShow.call(this, options)}}

指标测试  做了这么多,到底有没用,拿出来溜一溜就清楚了。  测试平台:iphone7、三星s7 、小程序开发工具  测试流程:首页 -> 配送到家 -> 加入购物车 -> 结算 ->查看订单  测试指标:调用setData次数,渲染总耗时,平均单次渲染耗时

优化后setData次数平均下降150次。  渲染耗时越是卡顿的机器,收益越大,三星s7平均每次渲染耗时降低826ms。

关于“小程序redux性能优化的方法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: 小程序redux性能优化的方法

本文链接: https://www.lsjlt.com/news/308296.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 小程序redux性能优化的方法
    这篇文章主要介绍“小程序redux性能优化的方法”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“小程序redux性能优化的方法”文章能帮助大家解决问题。首先了解小程序的工作原理和性能关键点。1工作原理...
    99+
    2023-06-26
  • 微信小程序调起键盘性能优化的方法
    本篇内容主要讲解“微信小程序调起键盘性能优化的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“微信小程序调起键盘性能优化的方法”吧!需求分析最近在项目中有一个需求,是从列表页点击评论按钮进入详...
    99+
    2023-06-26
  • python 性能优化方法小结
    提高性能有如下方法 1、Cython,用于合并python和c语言静态编译泛型 2、IPython.parallel,用于在本地或者集群上并行执行代码 3、numexpr,用于快速数值运算 4、multip...
    99+
    2022-06-04
    小结 性能 方法
  • 微信小程序性能如何优化
    这篇文章主要介绍了微信小程序性能如何优化的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇微信小程序性能如何优化文章都会有所收获,下面我们一起来看看吧。为什么要做性能优化?一切性能优化都是为了体验优化1. 使用小程...
    99+
    2023-06-26
  • 微信小程序代码包大小的优化方法
    这篇文章主要讲解了“微信小程序代码包大小的优化方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“微信小程序代码包大小的优化方法”吧!setDatasetData是小程序开发中使用最频繁的接口...
    99+
    2023-06-26
  • Nginx性能优化的方法
    这篇文章主要介绍了Nginx性能优化的方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Nginx性能优化的方法文章都会有所收获,下面我们一起来看看吧。Linux系统参数优化下文中提到的一些配置,需要较新的Li...
    99+
    2023-06-27
  • Android性能优化方法
    GPU过度绘制  •打开开发者选型,“调试GPU过度绘制”,蓝、绿、粉红、红,过度绘制依次加深  •粉红色尽量优化,界面尽量保持蓝绿...
    99+
    2022-06-06
    方法 优化 Android
  • Vue项目性能优化的方法教程
    本篇内容主要讲解“Vue项目性能优化的方法教程”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue项目性能优化的方法教程”吧!一、代码层面的优化1.1、v-if...
    99+
    2022-10-19
  • 小程序多图列表怎么实现性能优化
    小编给大家分享一下小程序多图列表怎么实现性能优化,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!什么造成的性能问题简单的来说: D...
    99+
    2022-10-19
  • Windows系统对于ASP程序的性能优化有哪些方法?
    ASP是一种常见的网页开发语言,它能够快速地生成动态网页,但在高并发、大流量的情况下,ASP程序的性能可能会出现瓶颈。为了解决这个问题,我们需要对Windows系统下ASP程序的性能优化进行深入了解和研究。 使用缓存 当用户频繁地访问...
    99+
    2023-08-16
    windows linux leetcode
  • MySQL的性能优化方法论
    作者:禅与计算机程序设计艺术 1.简介 一、什么是MySQL? MySQL是一个开源的关系型数据库管理系统,由瑞典MySQL AB开发并发布。它的目的是为了快速、可靠地处理复杂的事务处理,支持多种编...
    99+
    2023-10-18
    大数据 人工智能 语言模型 Java Python 架构设计
  • 怎么优化void程序的性能
    这篇文章主要介绍“怎么优化void程序的性能”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么优化void程序的性能”文章能帮助大家解决问题。我们的编译器已经提供了很好的优化机制,但是还有很多细节编...
    99+
    2023-06-04
  • iOS程序性能优化的技巧
    1. 用ARC管理内存 ARC(Automatic ReferenceCounting, 自动引用计数)和iOS5一起发布,它避免了最常见的也就是经常是由于我们忘记释放内存所造成的内...
    99+
    2022-05-15
    ios 程序 性能 优化
  • 如何优化JavaScript程序的性能
    如何优化JavaScript程序的性能,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。避免全局查找在一个函数中会用到全局对象存储为局部变量来减少...
    99+
    2022-10-19
  • 性能优化指南:性能优化的一般性原则与方法
    【本文转自博客园 作者:xybaby 原文链接:https://www.cnblogs.com/xybaby/p/9055734.html】作为一个程序员,性能优化是常有的事情,不管是桌面应用还是web应用,不管是前端还是后端,不管是单点应...
    99+
    2023-06-05
  • wpf程序性能如何优化
    WPF程序的性能优化可以从以下几个方面进行:1. 减少UI元素的数量和复杂度:尽量减少窗口中的控件数量,避免使用大量嵌套的控件和复杂...
    99+
    2023-10-18
    wpf
  • 优化iOS程序性能的二十五个方法分别是哪些
    这篇文章给大家介绍优化iOS程序性能的二十五个方法分别是哪些,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1. 用ARC管理内存ARC(Automatic ReferenceCount...
    99+
    2022-10-19
  • Android性能优化之图片大小,尺寸压缩的方法
    这篇文章主要介绍“Android性能优化之图片大小,尺寸压缩的方法”,在日常操作中,相信很多人在Android性能优化之图片大小,尺寸压缩的方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Android性能...
    99+
    2023-06-30
  • 如何优化HTML5 Canvas程序的性能
    这篇文章主要介绍了如何优化HTML5 Canvas程序的性能的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何优化HTML5 Canvas程序的性能文章都会有所收获,下面我们一...
    99+
    2022-10-19
  • SQL性能优化方法及性能测试
    目录笛卡尔连接分页limit的sql优化的几种方法count 优化方案笛卡尔连接 例1: 没有携带on的条件字句,此条slq查询的结构集等价于,a表包含的条数*b表包含的乘积: se...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作