我有这样的对象数组,我想根据2键删除重复的项目,在我的数据中,我想删除具有room_id
和mdate
相同的项目,在下面的代码对象4和5中,具有相同的room_id和mdate,因此我应该删除其中之一,任何解决方案吗?
我具有删除重复对象的功能,但可以检查一个键
function getUnique(arr, comp) {
arr.map()
const unique = arr
.map(e => e[comp])
// store the keys of the unique objects
.map((e, i, final) => final.indexOf(e) === i && i)
// eliminate the dead keys & store unique objects
.filter(e => arr[e])
.map(e => arr[e]);
return unique;
}
arr = [{
cond: 2
extra_fee: 20000
kind: ""
mdate: "2019-12-15"
price: "100000"
room_id: 1
},
{
cond: 2
extra_fee: 20000
kind: ""
mdate: "2019-12-10"
price: "100000"
room_id: 1
},
{
cond: 2
extra_fee: 20000
kind: "" object 3 <-------------- is same - have same mdate and room_id
mdate: "2019-12-10"
price: "100000"
room_id: 2
},
{
cond: 2
extra_fee: 20000
kind: ""
mdate: "2019-12-10"
price: "100000"
room_id: 2 object 4 <-------------- are same - have same mdate and room_id
},
{
cond: 2
extra_fee: 20000
kind: ""
mdate: "2019-12-10"
price: "100000"
room_id: 7
}
]
尝试一下:
function getUnique(arr, comp) {
let tmpObj = {};
let unique = [];
for (let i = 0; i < arr.length; i++) {
if (tmpObj[arr[i][comp]] === undefined) {
tmpObj[arr[i][comp]] = arr[i][comp];
unique.push(arr[i]);
}
}
return unique;
}
let arr = [{
cond: 2,
extra_fee: 20000,
kind: "",
mdate: "2019-12-15",
price: "100000",
room_id: 1
},
{
cond: 2,
extra_fee: 20000,
kind: "",
mdate: "2019-12-10",
price: "100000",
room_id: 1
},
{
cond: 2,
extra_fee: 20000,
kind: "",
mdate: "2019-12-10",
price: "100000",
room_id: 2
},
{
cond: 2,
extra_fee: 20000,
kind: "",
mdate: "2019-12-10",
price: "100000",
room_id: 2
},
{
cond: 2,
extra_fee: 20000,
kind: "",
mdate: "2019-12-10",
price: "100000",
room_id: 7
}
]
console.log(getUnique(arr, "room_id"));
通过这种方式可以做到
let arr = [{
cond: 2,
extra_fee: 20000,
kind: "",
mdate: "2019-12-15",
price: "100000",
room_id: 1,
},
{
cond: 2,
extra_fee: 20000,
kind: "",
mdate: "2019-12-10",
price: "100000",
room_id: 1,
},
{
cond: 2,
extra_fee: 20000,
kind: "",
mdate: "2019-12-10",
price: "100000",
room_id: 2,
},
{
cond: 2,
extra_fee: 20000,
kind: "",
mdate: "2019-12-10",
price: "100000",
room_id: 2,
},
{
cond: 2,
extra_fee: 20000,
kind: "",
mdate: "2019-12-10",
price: "100000",
room_id: 7,
}
]
let uniq = _.uniqBy(arr, ['room_id','mdate'])
console.log(uniq)
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.17.15/lodash.min.js"></script>