Hoe kan JSON structuur te veranderen om te kijken als een ander json structuur

stemmen
2

Ik wil mijn JSON structuur te veranderen, hoe kan ik dat doen?

im het krijgen van een JSON dat ziet er als volgt uit:

 body: {
     111111: {
         name: exp1,
         status: 10000
     },
     222222: {
         name: exp2,
         status: 20000
     },
     333333: {
         name: exp3,
         status: 30000
     }
 }

maar ik heb het nodig in deze structuur:

 body: {
     bulks: [{
         id: 111111,
         name: exp1,
         status: 100000
     }, {
         id: 222222,
         name: exp2,
         status: 200000
     }, {
         id: 333333,
         name: exp3,
         status: 300000
     }]
 }

Want in mijn html Ik wil om het te lezen als volgt:

<div *ngIf=showingList>
  <div class=list-bg  *ngFor=#bulk of listBulks | async>
    ID: `bulk`.`id` name of item: `bulk`.`name`
  </div>
</div>
De vraag is gesteld op 25/07/2016 om 10:59
user
In andere talen...                            


2 antwoorden

stemmen
2

Hier is mijn oplossing.

var req = {

  "111111": {
    "name": "exp1",
    "status": 10000
  },
  "222222": {
    "name": "exp2",
    "status": 20000
  },
  "333333": {
    "name": "exp3",
    "status": 30000
  }
}


var res = {
	bulks: []
};
for (var key in req) {
  if (req.hasOwnProperty(key)) {
    var temp = req[key];
    temp["id"] = key;
    res.bulks.push(temp);
  }
}

console.log(res);

antwoordde op 25/07/2016 om 11:09
bron van user

stemmen
1

U kunt dit doen met behulp van te verminderen:

var body = {
    "111111": {
        "name": "exp1",
        "status": 10000
    },
    "222222": {
        "name": "exp2",
        "status": 20000
    },
    "333333": {
        "name": "exp3",
        "status": 30000
    }
}

var bodyArray = Object.keys(body).reduce(function(result, key) {
    var item = body[key];
    item.id = key;
    result.push(item)
    return result;
}, []);
antwoordde op 25/07/2016 om 11:09
bron van user

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more