var a=[{"id":"1001","name":"張三","age":"18","address":"北京市朝陽區","school":"朝陽區第二中學"},{"id":"1002","name":"李四","age":"15","address":"北京市海淀區","school":"海淀區第二中學"},{"id":"1003","name":"王五","age":"16","address":"北京市石景山區","school":"石景山區第二中學"}];
var b=[{"id":"1004","name":"小毛","age":"18","address":"北京市朝陽區","school":"朝陽區第二中學"},{"id":"1003","name":"王五","age":"16","address":"北京市石景山區","school":"石景山區第二中學"}]
var c = a.concat(b); //合並數組
var temp = {}; //存放id
var result = []; //新數組
c.map((item,index) => {
if(!temp[item.id]){
result.push(item);
temp[item.id] = true;
}
})
document.getElementById('txt').innerHTML = JSON.stringify(result)
有兩個json數組demo1和demo2
var demo1 = [{"id": 0, "name": "牛肉"},{"id": 1,"name": "羊肉"}];
var demo2 = [{"id": 2, "name": "牛肉"},{"id": 3,"name": "魚肉"},{ "id": 4,"name":"雞肉"}];
數組合並
var totalDemo = demo1.concat(demo2);
console.log(totalDemo); //[{"id": 0, "name": "牛肉"},{"id": 1,"name": "羊肉"},{"id": 2, "name": "牛肉"},{"id": 3,"name": "魚肉"},{ "id": 4,"name":"雞肉"}]
數組合並用的是concat方法,它可以用於字符串之間的連接和數組之間的連接。
數組去重
上面已經得到合並的數組 totalDemo ,去掉name屬性是一樣的json對象
var temp = {}; //用於name判斷重復
var result = []; //最后的新數組
totalDemo.map(function (item, index) {
if(!temp[item.name]){
result.push(item);
temp[item.name] = true;
}
});
console.log(result);//[{"id": 0, "name": "牛肉"},{"id": 1,"name": "羊肉"},{"id": 3,"name": "魚肉"},{ "id": 4,"name":"雞肉"}];
map方法:按照原始數組元素順序依次處理元素。可以在map方法里面輸入console.log(item)打印看下,它會把數組中的對象依次打印出來。