纯数字数组去重
const numbers = [1, 1, 20, 3, 3, 3, 9, 9];
const uniqueNumbers = [...new Set(numbers)]
//输出uniqueNumbers = [1, 20, 3, 9]
forEach判断数组是否含有该字段
let flag = false;
let key1 = xxx;
arr.forEach(function (val, index) {
if (key1 !== "") {
if (key1 === val.key) {
flag = true
return false
}
}
});
单个数组通过某个字段名去重value值
var arr = [{
key: '01',
value: '乐乐'
}, {
key: '02',
value: '博博'
}, {
key: '03',
value: '淘淘'
},{
key: '04',
value: '哈哈'
},{
key: '01',
value: '乐乐'
}];
方法1:利用对象访问属性的方法,判断对象中是否存在相同的key
var result = [];
var obj = {};
for(var i =0; i<arr.length; i++){
if(!obj[arr[i].key]){
result.push(arr[i]);
obj[arr[i].key] = true;
}
}
console.log(result);
// [{key: "01", value: "乐乐"},{key: "02", value: "博博"},{key: "03", value: "淘淘"},{key: "04", value: "哈哈"}]
方法2:利用reduce方法遍历数组,reduce第一个参数是遍历需要执行的函数,第二个参数是item的初始值
var obj = {};
arr = arr.reduce(function(item, next) {
obj[next.key] ? '' : obj[next.key] = true && item.push(next);
return item;
}, []);
console.log(arr);
// [{key: "01", value: "乐乐"},{key: "02", value: "博博"},{key: "03", value: "淘淘"},{key: "04", value: "哈哈"}]
多个数组合并同时根据某个字段进行去重
let arr1 = [
{ key: '1', value: '老哒'},
{ key: '2', value: '老鹅'},
{ key: '3', value: '老叁'},
{ key: '4', value: '老寺'}
]
let arr2 = [
{ key: '4', value: '老寺'},
{ key: '5', value: '老悟'},
{ key: '6', value: '老陆'}
]
const arr3 = [...arr1, ...arr2]
const map = new Map()
for (const item of arr3) {
if (!map.has(item.key)) {
map.set(item.key, item)
}
}
var result = [...map.values()]
console.log(result)
//result = [
{
"key": "1",
"value": "老哒"
},
{
"key": "2",
"value": "老鹅"
},
{
"key": "3",
"value": "老叁"
},
{
"key": "4",
"value": "老寺"
},
{
"key": "5",
"value": "老悟"
},
{
"key": "6",
"value": "老陆"
}
]