作者:只因为汰假_汰傻_615 | 来源:互联网 | 2023-02-06 19:07
官方文档
//像这些代码能理解
this.setData({
'array[0].text': 'changed data',
});
//网上说,如果序号是动态的(i、j、k之类的),就是这些代码,虽然不理解,但能工作就ok了。
this.setData({
['array[' + i + '].text']: 'changed data',
});
//但是删除数组元素怎么搞?
//1、*******************我是这么干的,原始数组删除元素之后,再整体set回去:
this.data.array.splice(i, 2);
this.setData({
'array': this.data.array,
});
//总感觉不靠谱啊。第一:鬼知道什么时候超出1024kB啊。
//第二:原始数组set回去,会不会出错。我测试了,似能行,但总觉得会有隐患似的。
//就感觉讨了个二手夫人一样,总怀疑她的子宫到底吸收了多少第一个男人的DNA。唉。
//2、*******************如果是复制一份副本出来,删除元素之后,再整体set回去。
//增加代码量,而且还是没有避免1024kB的梗。
//3、*******************如果是set某个元素为null,好奇葩不说,不知道有没有隐患。
this.setData({
‘array[2]’: null,
});
//4、*******************为了1024kB的梗,我想到的是:先清空,再一个个set上去。
//但是这个方法,界面上会闪一下。哎。
this.setData({
array: [],
});
for(var i in tmp) {
this.setData({
['array[' + i + ']']: tmp[i],
});
}
3 个解决方案
this.data.list.splice(1,1)
从index为id的位置开始,删除i个元素
this.setData({ list: this.data.list})
删除完再调用一次setData