使用对象克隆方法和for循环将对象推入数组,对象仍然是相同的引用并且在数组中是相同的
Using an object clone method and a for loop to push objects into array, the objects are all still the same reference and are the same in the array
let promiseArr = [];
for (let i = 0; i < ISOarr.length; i++) {
options.body.start_time = ISOarr[i];
let newOptions = cloneOptions(options);
promiseArr.push(newOptions);
}
console.log(promiseArr);
Returns 同一对象的数组。
克隆方法:
cloneOptions = options => {
let clone = {};
for( let key in options ) {
clone[key] = options[key]
}
return clone;
}
所以我的问题是如何推送一个与之前推送的对象引用不同的对象,因为即使它应该在每个循环中创建一个新的克隆,它仍然以某种方式创建相同的引用对象。
在循环中,如果我 console.log 我得到了正确的输出,键的值发生了变化,但是一旦它被推入数组并且我们 console.log 数组,所有对象都是相同的。任何建议都会非常有帮助。提前致谢!
你能试试这个吗
cloneOptions = options => {
return JSON.parse(JSON.stringify(options))
}
let promiseArr = [];
for (let i = 0; i < ISOarr.length; i++) {
options.body.start_time = ISOarr[i];
let newOptions = cloneOptions(options);
promiseArr.push(newOptions);
}
console.log(promiseArr);
Returns 同一对象的数组。 克隆方法:
cloneOptions = options => {
let clone = {};
for( let key in options ) {
clone[key] = options[key]
}
return clone;
}
所以我的问题是如何推送一个与之前推送的对象引用不同的对象,因为即使它应该在每个循环中创建一个新的克隆,它仍然以某种方式创建相同的引用对象。 在循环中,如果我 console.log 我得到了正确的输出,键的值发生了变化,但是一旦它被推入数组并且我们 console.log 数组,所有对象都是相同的。任何建议都会非常有帮助。提前致谢!
你能试试这个吗
cloneOptions = options => {
return JSON.parse(JSON.stringify(options))
}