gpt4 book ai didi

javascript - 在 JavaScript 中克隆变量不起作用

转载 作者:行者123 更新时间:2023-12-03 04:49:27 24 4
gpt4 key购买 nike

我有一个数组字典,如下:

var usersTemp = {11: [ {"active": true, "email": "seconduser@example.com", "userid": 2, } ],
12: [ {"active": true, "email": "firstuser@example.com", "userid": 1, },
{"active": true, "email": "seconduser@example.com", "userid": 2, } ], }

我需要合并具有相同电子邮件地址或用户 ID 的元素,并得到与此类似的内容:

{ 1: {"active": true, "email": "firstuser@example.com", "roles": [12]} ,
2: {"active": true, "email": "seconduser@example.com", "roles": [11 , 12]}, }

这是我的尝试:

var mergedUsersTemp = {};
for (var role in usersTemp) {
for (var user in usersTemp[role]) {
if(!mergedUsersTemp[user]){
const i = JSON.parse(JSON.stringify(usersTemp[role][user]));
console.log(JSON.stringify(i))
mergedUsersTemp[user] = {"active": i["active"], "email": i["email"], "id": i["id"], "roles": []};
mergedUsersTemp[user]["roles"] = [];
}
mergedUsersTemp[user]["roles"].push(role);
}
}

但问题是 JavaScript 中的深度复制,它为用户信息返回相同的值。我该如何修复它?

最佳答案

使用 Object.keys()forEach 循环代替 for...in 循环更容易。然后,您只需首先检查对象中是否已存在 userid 并设置其值或添加到 Angular 色并更改为事件状态。

var usersTemp = {
11: [{
"active": true,
"email": "seconduser@example.com",
"userid": 2,
}],
12: [{
"active": true,
"email": "firstuser@example.com",
"userid": 1,
}, {
"active": true,
"email": "seconduser@example.com",
"userid": 2,
}],
}

var result = {}
Object.keys(usersTemp).forEach(function(i) {
usersTemp[i].forEach(function(j) {
if (!result[j.userid]) {
result[j.userid] = {
active: j.active,
email: j.email,
roles: []
}
}
result[j.userid].roles.push(i)
result[j.userid].active = j.active
})
})

console.log(result)

关于javascript - 在 JavaScript 中克隆变量不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42722684/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com