deserialize Jackson object in JavaScript containing JsonIdentityInfo

前端 未结 2 1770
独厮守ぢ
独厮守ぢ 2020-11-30 07:24

hello (sorry for my english)

I\'m working on angularjs front end website consuming web service producing json with SPRING MVC. The spring mvc use JsonIdentityInfo op

2条回答
  •  天命终不由人
    2020-11-30 07:26

    Split all the array members into new arrays: those with a full component attribute (not just a number) and those without. Loop through the remaining original members which should have just numerical component attributes, then look up the corresponding @componentID from the "good" array, and do some copying and moving.

    // initialize some vars
    var final = [], temp = [], bad = [],
        c = {},
        computers = [
          {
            "@computerID": 1,
            "component": {
              "@componentID": 2,
              "processor": 2,
              "ram": "8g",
              "harddrive": "wd"
            }
          },
          {
            "@computerID": 3,
            "component": 2
          }
        ];
    
    // split original array into 3: final, bad, & temp
    while(computers.length > 0) {
        c = computers.pop();
        if (c.hasOwnProperty("component")) {
            if (typeof c.component === "number") {
                temp.push(c);
            } else {
                final.push(c);
            }
        } else {
            bad.push(c);
        }
    }
    
    // loop through temp & look up @componentID within final
    while (temp.length > 0) {
        c = temp.pop();
        // should @componentID be 1-of-a-kind?
        var found = getObjects(final, "@componentID", c.component);
        if (found.length) {
            c.component = found[0];
            final.push(c);
        } else {
            bad.push(c);
        }
    }
    
    
    // SOURCE: http://stackoverflow.com/a/4992429/1072176
    function getObjects(obj, key, val) {
        var objects = [];
        for (var i in obj) {
            if (!obj.hasOwnProperty(i)) continue;
            if (typeof obj[i] == 'object') {
                objects = objects.concat(getObjects(obj[i], key, val));
            } else if (i == key && obj[key] == val) {
                objects.push(obj);
            }
        }
        return objects;
    }
    
    // should result in just one or two populated arrays: final and/or bad
    alert(JSON.stringify(final));
    

    You'll note I actually made THREE arrays, but only two end up populated: final has your good new objects, and the other one (bad) is a catch-all for objects without a component attribute, or for whose component number a corresponding @componentID cannot be found.

提交回复
热议问题