版权声明:本文为博主原创文章,未经博主允许转载将负法律责任。 https://blog.csdn.net/ningmengbaby/article/details/86437846
之前在写代码定义个新的数组,每次将最新的对象push到数组中的时候被最后一条代码覆盖的几率特别大,这次终于明白是为什么了。防止被覆盖有以下几种办法
办法1.
this.users.forEach(element => {
const result = /[\u4e00-\u9fa5]/g;
const name = element.match(result).join('');
this.ts = new UserItem();
this.ts.name = name;
// 去掉汉字,留有id
const id = element.replace(result, '');
this. ts.id = id;
this.receiveUser.push(this.ts);
});
这里面的关键点是重新实例化清空。this.ts = new userItem()
能用this,是因为全局定义了。
方法2.
this.users.forEach(element => {
var result = /[\u4e00-\u9fa5]/g;
var name = element.match(result).join('');
var ts = new UserItem(); -------重新实例化是重点
ts.name = name;
// 去掉汉字,留有id
var id = element.replace(result, '');
ts.id = id;
this.receiveUser.push(ts);
});
这种方法是局部定义。
防止被覆盖最重要的一点就是在push之前把之前的数据清空,重新定义以下。