Javascript 使用对象克隆方法和for循环将对象推送到数组中,对象仍然是相同的引用,并且在数组中也是相同的

Javascript 使用对象克隆方法和for循环将对象推送到数组中,对象仍然是相同的引用,并且在数组中也是相同的,javascript,arrays,object,clone,Javascript,Arrays,Object,Clone,因此,我的问题是,如何推送一个与先前推送的对象不相同的引用的对象,因为即使假设它在每个循环中创建一个新的克隆,它仍然以某种方式创建相同的引用对象。 在循环中,如果I console.log更改了键的值,我得到了正确的输出,但是一旦它被推入数组,并且我们console.log数组,所有对象都是相同的。任何建议都会非常有用。提前谢谢你 你能试试这个吗 cloneOptions = options => { let clone = {}; for( let key in opti

因此,我的问题是,如何推送一个与先前推送的对象不相同的引用的对象,因为即使假设它在每个循环中创建一个新的克隆,它仍然以某种方式创建相同的引用对象。 在循环中,如果I console.log更改了键的值,我得到了正确的输出,但是一旦它被推入数组,并且我们console.log数组,所有对象都是相同的。任何建议都会非常有用。提前谢谢你

你能试试这个吗

cloneOptions = options => {
    let clone = {};
    for( let key in options ) {
        clone[key] = options[key]
    }
    return clone;
}

对于深度复制,这是在JSYeah中克隆对象的最佳方法。我猜另一种方法只能创建浅层复制。是的,其他方法,内部对象总是创建为浅层复制
cloneOptions = options => {
    let clone = {};
    for( let key in options ) {
        clone[key] = options[key]
    }
    return clone;
}
cloneOptions = options => {
return JSON.parse(JSON.stringify(options))
}