【发布时间】:2020-04-24 23:55:02
【问题描述】:
在我的 Angular 应用程序中,我试图仅获取从 UI 修改的更新数组。
在这里,我有两个数组,其中一个角色名称已更改。我想比较并过滤掉修改过的对象,只返回那些修改过的数组。 (在这种情况下,role_name 值被修改)
我尝试在 ES6 的帮助下进行过滤,但它不起作用。
有人可以帮我解决我在哪里失踪吗?
var arr1 = [ {
"num" : null,
"role_name" : "ABC",
"profile" : "ff",
"user" : "1234",
"rn" : "1",
"user_name" : "Rywan"
},
{
"num" : null,
"role_name" : "DEF",
"profile" : "ff",
"user" : "1234",
"rn" : "2",
"user_name" : "adecg"
},
{
"num" : null,
"role_name" : "GHJ",
"profile" : "ff",
"user" : "1234",
"rn" : "3",
"user_name" : "dde"
},
{
"num" : null,
"role_name" : "RRT",
"profile" : "ff",
"user" : "1234",
"rn" : "4",
"user_name" : "kumar"
},
{
"num" : null,
"role_name" : "SFR",
"profile" : "ff",
"user" : "1234",
"rn" : "5",
"user_name" : "SASI"
}
];
var arr2 = [ {
"num" : null,
"role_name" : "ABC",
"profile" : "ff",
"user" : "1234",
"rn" : "1",
"user_name" : "Rywan"
},
{
"num" : null,
"role_name" : "ROLE_CHANGED",
"profile" : "ff",
"user" : "1234",
"rn" : "2",
"user_name" : "adecg"
},
{
"num" : null,
"role_name" : "GHJ",
"profile" : "ff",
"user" : "1234",
"rn" : "3",
"user_name" : "dde"
},
{
"num" : null,
"role_name" : "RRT",
"profile" : "ff",
"user" : "1234",
"rn" : "4",
"user_name" : "kumar"
},
{
"num" : null,
"role_name" : "SFR",
"profile" : "ff",
"user" : "1234",
"rn" : "5",
"user_name" : "SASI"
}
];
let filteredData;
filteredData = arr1.filter(function(o1){
//filter out (!) items in arr2
return arr2.some(function(o2){
return o1.role_name !== o2.role_name;
});
});
console.log(filteredData);
输出应该是
[
{
"num" : null,
"role_name" : "ROLE_CHANGED",
"profile" : "ff",
"user" : "1234",
"rn" : "2",
"user_name" : "adecg"
}
]
【问题讨论】:
-
如果预计两个数组中元素的顺序相同,则可以执行以下操作:
const filteredData = arr2.filter((item, index) => item.role_name !== arr1[index].role_name);
标签: javascript arrays angular typescript ecmascript-6