比如一个商品列表页,用户不断上滑加载数据,而每次加载数据时通常都是将获取的新数据和旧数据通过concat进行合并在一个数组内,
this.setData({
list: this.data.list.concat(newlist)
})
这导致数组越来越大,setData渲染时也会越来越慢。
改善方法:
this.setData({
['list[' + this.data.list.length + ']']: newlist
});
这样只是在list中多添加了一个元素,此时,list的结构是这样的:
是一个二维数组,所以在wxml页面循环时要多一层循环。在渲染时不会渲染整个list。
同理,假如现在商品列表有个点赞功能,对某个商品点赞后,只要知道商品在list中的下标位置就可以获取到该商品数据,修改后再用setData渲染:
var goods = this.data.list[0][0];
goods['dianzan']+=1;
this.setData({
['list[0][0]']: goods
})
这样渲染时也会很快。