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);
// 方法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);
let a = this.tabsData[this.tabIndex - 1].relate_data;
let arr = a.concat(newVal); //合並數組
// 數組去重 arr:數組;key:根據數組中為key的鍵名去重
filterArr(arr, key) {
let hash = {};
return arr.reduce((ss, item) => {
hash[item[key]] ? '' : (hash[item[key]] = true && ss.push(item));
return ss;
}, []);
},
// 返回新的對象的數組
changeArr(arr, type, name) {
let data = [];
arr.map(item => {
const obj = {};
obj.name = item[`${name}`];
obj.res_id = item.id;
obj.type = type;
data.push(obj);
});
return data;
},