随手记:小程序setData 数据传输长度为 XXXKB,存在有性能问题!小程序长列表性能优化,uni.createIntersectionObserver

在一些小程序列表的页面,总是会看到小程序控制台的黄色警告:

这是由于data 数据过大,导致的问题

方法:

1.避免setData的数据过大,小于1024kb。

2.避免调用频繁,保证数据实时性。

3.避免未绑定在WXML的变量传入setData,也就是不显示的数据不写入方法中。

4.不需要使用的字段让后端删除

5.尽量避免大循环

6.尝试使用uni.createIntersectionObserver

重点尝试uni.createIntersectionObserver

传送门:https://uniapp.dcloud.net.cn/api/ui/intersection-observer.html#createintersectionobserver

思路参考:

用户在划动列表的时候,离开可视范围的数据卸载dom元素,在接近可视范围的时候挂在dom元素,这样可以减少dom元素的数量以达到性能优化的目的

获取到数据的时候给数据初始化增加单个item是否展示的show,默认为true,单个item初始化的实例值为null,单个item的高度为0,然后获取到单个item的id,给每个item绑定一个createIntersectionObserver实例,这个实例返回的参数有个intersectionRatio为相交点的值,如果intersectionRatio为0则表示当前这个item不在可视范围,可以卸载dom元素,不等0的时候就是item在可视范围之内,需要展示dom元素

在获取到后端数据的时候增加初始化值

前后代码逻辑忽略:

获取到数据之后,做生成实例处理:

javascript 复制代码
				// ----性能优化方案
				this.$nextTick(() => {
					this.prescriptionList.forEach(item => {
						// 判断为创建过实例
						if(!item.observer) {
							// 创建并返回一个 IntersectionObserver 对象实例
							item.observer = uni.createIntersectionObserver(this);
							// 指定页面显示区域作为参照区域之一,假设windowHeight=617,即超出屏幕上方617*2px和超出屏幕下方617*2px时,则把dom元素v-if隐藏
							console.log('this.$system.windowHeight', this.$system.windowHeight,'this.$system.windowHeight')
							item.observer.relativeToViewport({ top: this.$system.windowHeight * 2, bottom: this.$system.windowHeight * 2 })
							.observe(`#${item.virtualId}`, res => {
								/**
								 * 指定目标节点并开始监听相交状态变化情况。回调函数callback包含一个参数result。observe(selector, [callback])
								 * intersectionRatio:相交比例-最大值1-最小值0,0~1区间
								*/
							   item.intersectionRatio = res.intersectionRatio;
								if(res.intersectionRatio === 0) {
									// 超过预定范围,从页面卸载dom元素
									item.virtualShow = false;
								}else {
									// 达到预定范围,将dom元素渲染进页面
									item.virtualShow = true;
									// 拿到当前item的高度
									item.itemHeight = res.intersectionRect.height;
								}
							})
						}
					})
				})
相关推荐
ZeroNews内网穿透38 分钟前
ZeroNews IP 访问控制能力
服务器·网络·网络协议·tcp/ip·安全·web安全·小程序
seeyoutlb2 小时前
微信小程序登录
微信小程序·小程序
毕设源码-邱学长9 小时前
【开题答辩全过程】以 基于微信小程序的农商新闻网为例,包含答辩的问题和答案
微信小程序·小程序
小光学长9 小时前
基于微信小程序的家具商城系统g80l9675(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·微信小程序·小程序
云起SAAS9 小时前
1V1七彩测评抖音快手微信小程序看广告流量主开源
微信小程序·小程序·ai编程·看广告变现轻·1v1七彩测评
说私域9 小时前
定制开发开源AI智能名片S2B2C商城小程序:产业互联网浪潮下的商业模式创新
人工智能·小程序·开源
sheji34169 小时前
【开题答辩全过程】以 基于微信小程序的签到系统的设计与实现为例,包含答辩的问题和答案
微信小程序·小程序
说私域12 小时前
基于开源链动2+1模式AI智能名片S2B2C商城小程序的社群运营创新研究
人工智能·小程序·开源
chinrock12 小时前
如何抓包飞书小程序-飞书开发者工具
小程序·飞书
vx_dmxq2111 天前
【微信小程序学习交流平台】(免费领源码+演示录像)|可做计算机毕设Java、Python、PHP、小程序APP、C#、爬虫大数据、单片机、文案
java·spring boot·python·mysql·微信小程序·小程序·idea