欢迎来到258分享网,纯净的网络源码分享基地!

258资源分享网

全部作品
全部作品
网站源码
微信源码
素材特效
源码插件
视频教程
建站学院
热门搜索: 织梦  农业种植  农业  安全设置  官方
258资源分享 > 建站学院 > 微信开发 > 说说微信小程序开发的那些坑--setData

推荐下载

HTML5响应式自适应网咯设计

2020-05-12   浏览:789

HTML5自适应律师工作室类网

2020-04-04   浏览:654

高端HTML5响应式企业通用网

2020-05-06   浏览:560

html5响应式外贸网站英文版

2020-05-08   浏览:545

HTML5影视传媒文化公司类网

2020-05-12   浏览:543

说说微信小程序开发的那些坑--setData

发布时间:2020-11-05  

this.setData估计是小程序中最经常用到的一个方法,但是要注意其实他是有限制的,忽略这些限制的话,会导致数据无法更新

setData的反模式:
-- 短时间频繁进行setData操作
--页面进入后台后依然进行setData操作
-- 使用setData一次性设置太多的数据

这里重点说一下第3点,获取更新列表的时候非常容易触犯第三点,举个栗子:
假设Page中data有items的数据,装着列表的数据

Page({ data: { items: [], } });

一般情况下,更新items的操作可能如下:

loadItems() { //假设通过API获取到新的列表数据:newItems const { items } = this.data; this.setData({ items: items.concat(newItems) }) }

如果完整items的数据量不大的时候,这样做也是可以的,但是列表的数据比较多的时候,后面loadItems时setData的数据就会变很大,超过一定值(1048576)后就会报以下错误,然后列表无法再加载更多

数据传输长度为 xxxxxx 已经超过最大长度 1048576

若遇到这样的情况,我的解决方法是

loadItems() { //依然假设通过API获取到新的列表数据:newItems const { items } = this.data; const start = items.length; const updateItems = newItems.reduce((updateItems, item, index) => { const key = `items[${start + index}]`; updateItems[key] = item; return updateItems; }, {}) //updateItems 示例: { items[0]: 'content', item[1]: 'content', ... } this.setData(updateItems) }

以上是我开发时遇到的坑,欢迎大家探讨指导,感谢阅读