web-dev-qa-db-fra.com

Masquer les valeurs nulles dans la sortie de JSON.stringify ()

Dans mon code, toutes les informations d'une ligne de table Postgres sont stringified lorsqu'un rowID spécifique est sélectionné.

var jsonRes = result.message.rows;

document.getElementById('panel').innerHTML = '<pre>' + JSON.stringify(jsonRes[0], null, "\t") + '</pre>'

Le résultat ressemble à ceci:

{
  "ogc_fid": 143667,
  "relkey": 288007,
  "acct": "000487000A0010000",
  "recacs": "12.5495 AC",
  "shape_star": 547131.567383,
  "shape_stle": 3518.469618,
  "objectid": 307755,
  "zone_dist": "MU-3",
  "pd_num": null,
  "council_da": null,
  "long_zone_": "MU-3",
  "globalid": "{D5B006E8-716A-421F-A78A-2D71ED1DC118}",
  "ord_num": null,
  "notes": null,
  "res_num": null,
  "effectived": 1345766400000,
  "shape.star": 629707.919922,
  "shape.stle": 3917.657332,
  "case_numbe": null,
  "common_nam": null,
  "districtus": null 
}

Je suis nouveau sur JS et je voudrais savoir s'il pourrait y avoir un moyen simple d'exclure complètement les colonnes contenant des valeurs nulles - une fonction qui ressemble à peu près à ceci:

function hide(jsonObject) {
    if (property === null) {
      hide property
  } else {
      return str
  }
}

Pour qu'à la fin, l'objet dans le panneau ressemble à ceci:

{
  "ogc_fid": 143667,
  "relkey": 288007,
  "acct": "000487000A0010000",
  "recacs": "12.5495 AC",
  "shape_star": 547131.567383,
  "shape_stle": 3518.469618,
  "objectid": 307755,
  "zone_dist": "MU-3",
  "long_zone_": "MU-3",
  "globalid": "{D5B006E8-716A-421F-A78A-2D71ED1DC118}",
  "effectived": 1345766400000,
  "shape.star": 629707.919922,
  "shape.stle": 3917.657332
}
15
the_darkside

Merci pour les réponses. Je viens de réaliser que JSON.stringify () a un paramètre REPLACER ( info ici )

Je viens donc d'ajouter:

function replacer(key, value) {
  // Filtering out properties
  if (value === null) {
    return undefined;
  }
  return value;
}

document.getElementById('panel').innerHTML =
  '<pre>' +
    JSON.stringify(jsonRes[0], replacer, "\t") +
  '</pre>'
;
11
the_darkside

Vous pouvez faire quelque chose comme ça:

let x = {
  'x1':0,
  'x2':null,
  'x3':"xyz", 
  'x4': null
}

console.log(JSON.stringify(x, (key, value) => {
  if (value !== null) return value
}))
24
mcrunix

Essaye ça:

function getCleanObject(jsonObject) {
    var clone = JSON.parse(JSON.stringify(jsonObject))
    for(var prop in clone)
       if(clone[prop] == null)
           delete clone[prop];
    return JSON.stringify(clone);
}
0
Slava Utesinov

Si vous souhaitez conserver votre objet initial, vous pouvez en créer un nouveau comme celui-ci

  var object = {
    "ogc_fid": 143667,
    "relkey": 288007,
    "acct": "000487000A0010000",
    "recacs": "12.5495 AC",
    "shape_star": 547131.567383,
    "shape_stle": 3518.469618,
    "objectid": 307755,
    "zone_dist": "MU-3",
    "pd_num": null,
    "council_da": null,
    "long_zone_": "MU-3",
    "globalid": "{D5B006E8-716A-421F-A78A-2D71ED1DC118}",
    "ord_num": null,
    "notes": null,
    "res_num": null,
    "effectived": 1345766400000,
    "shape.star": 629707.919922,
    "shape.stle": 3917.657332,
    "case_numbe": null,
    "common_nam": null,
    "districtus": null
  };

  var newObj = {};

  Object.keys(object).forEach(function(key) {
    if (object[key] !== null)
      newObj[key] = object[key];
  });
  console.log(newObj);
0
Weedoze