如下一個(gè)數(shù)組,怎么去除其中的重復(fù)對(duì)象,求大神給個(gè)方法,謝謝啊
arr = [
{orgId:"100",orgName:"信息組"},
{orgId:"100",orgName:"信息組"},
{orgId:"100",orgName:"信息組"},
{orgId:"81",orgName:"安全組"},
{orgId:"11",orgName:"秘書組"},
{orgId:"81",orgName:"安全組"}
]
以上答案都不支持排序混亂的情況下,且優(yōu)化一下(避免用Object.values()再進(jìn)行一次迭代),我補(bǔ)充下:
不改變目標(biāo)數(shù)組
因?yàn)橛袆?chuàng)建數(shù)組并追加的行為,且無(wú)法result=Array(length)來(lái)讓這行為提速,因此這種方式的效率會(huì)被給數(shù)組賦值所拖累。
let arr = [
{ orgId: '100', orgName: '信息組' },
{ orgName: '信息組', orgId: '100' },
{ orgId: '100', orgName: '01', a: 2 },
{ orgId: '01', orgName: '100', a: 2 },
{ orgId: '81', orgName: '安全組' },
{ orgId: '11', orgName: '秘書組' },
{ orgId: '81', orgName: '安全組' },
];
let temp = {},
result = [],
idx = -1,
unit;
arr.forEach( val => {
unit = Object.keys( val ).map( key => [ key, val[ key ] ] ).sort() + '';
temp[ unit ]
|| ( result[ ++idx ] = val, temp[ unit ] = 1 ) ;
} );
console.log( result );
改變目標(biāo)數(shù)組
源數(shù)組長(zhǎng)度越大,越突顯性能
let temp = {},
{ length } = arr;
for ( let idx = 0; idx < length; idx++ ) {
let val = arr[ idx ],
unit = Object.keys( val ).map( key => [ key, val[ key ] ] ).sort() + '';
temp[ unit ]
? ( arr.splice( idx, 1 ), idx--, length-- )
: temp[ unit ] = 1
};
console.log( arr );
可以這樣寫
//將對(duì)象元素轉(zhuǎn)換成字符串以作比較
function obj2key(obj, keys){
var n = keys.length,
key = [];
while(n--){
key.push(obj[keys[n]]);
}
return key.join('|');
}
//去重操作
function uniqeByKeys(array,keys){
var arr = [];
var hash = {};
for (var i = 0, j = array.length; i < j; i++) {
var k = obj2key(array[i], keys);
if (!(k in hash)) {
hash[k] = true;
arr .push(array[i]);
}
}
return arr ;
}
var array = [
{orgId:"100",orgName:"信息組"},
{orgId:"100",orgName:"信息組"},
{orgId:"100",orgName:"信息組"},
{orgId:"81",orgName:"安全組"},
{orgId:"11",orgName:"秘書組"},
{orgId:"81",orgName:"安全組"}
]
//進(jìn)行去重
var arr = uniqeByKeys(array,['orgId','orgName']);
斜體文字
按照你的對(duì)象來(lái)寫的,直接復(fù)制過(guò)去用就行。
var newArr = [];
var obj={};
//比較數(shù)組內(nèi)的屬性,并將其添加為obj的對(duì)象
for (var i = 0, length = arr.length; i < length; i++) {
//如果obj的orgid存在,說(shuō)明已經(jīng)重復(fù)
if(!obj[arr[i].orgId]){
newArr.push(arr[i])
//為obj的orgid屬性賦值
obj[arr[i].orgId]=-1
}
}
console.log(newArr) //這就是去重后的數(shù)組
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國(guó)家
北大青鳥中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團(tuán)創(chuàng)建于1999年,經(jīng)過(guò)二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機(jī)構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團(tuán),成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫(kù),具有快速界面開發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁(yè)制作和網(wǎng)頁(yè)游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問(wèn),美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。