JSON.stringify:如何跳过一个(或多个)对象的缩进

时间:2018-05-03 12:33:15

标签: javascript json indentation

我希望缩进某些特定子对象的之外的所有对象。

这是我最接近解决问题的方法。在示例中,我希望避免缩进color

let obj = {
    colorsPerValue: [
        { value: 0.0, color: { r: 240, g: 59, b: 32 } },
        { value: 0.5, color: { r: 255, g: 255, b: 255 } },
        { value: 1.0, color: { r: 44, g: 162, b: 95 } }
    ]
};
let str = JSON.stringify(obj, replacer, 2);
console.log(str);

replacer(name, val) {
    if (name === 'color') {
        return JSON.stringify(val); // stringify with no indentation
    } else {
        return val; // return as is
    }
};

期望的结果:

{
    colorsPerValue: [
        { 
            value: 0.0, 
            color: { r: 240, g: 59, b: 32 } 
        },
        { 
            value: 0.5, 
            color: { r: 255, g: 255, b: 255 } 
        },
        { 
            value: 1.0, 
            color: { r: 44, g: 162, b: 95 } 
        }
    ]
}

实际结果(您猜对了,return JSON.stringify(val);会返回序列化的string,这不是我想要的结果:

{
  "colorsPerValue": [
    {
      "value": 0,
      "color": "{\"r\":240,\"g\":59,\"b\":32}"
    },
    {
      "value": 0.5,
      "color": "{\"r\":255,\"g\":255,\"b\":255}"
    },
    {
      "value": 1,
      "color": "{\"r\":44,\"g\":162,\"b\":95}"
    }
  ]
}

let obj = {
  colorsPerValue: [
    { value: 0.0, color: { r: 240, g: 59, b: 32   } },
    { value: 0.5, color: { r: 255, g: 255, b: 255 } },
    { value: 1.0, color: { r: 44, g: 162, b: 95   } }
  ]
};
let str = JSON.stringify(obj, replacer, 2);
console.log(str);

function replacer(name, val) {
  if (name === 'color') {
    return JSON.stringify(val); // stringify with no indentation
  } else {
    return val; // return as is
  }
};

1 个答案:

答案 0 :(得分:1)

您可以删除以"color":开头的大括号中的所有空格。



var obj = {
        colorsPerValue: [
            { value: 0.0, color: { r: 240, g: 59, b: 32 } },
            { value: 0.5, color: { r: 255, g: 255, b: 255 } },
            { value: 1.0, color: { r: 44, g: 162, b: 95 } }
        ]
    },
    str = JSON
        .stringify(obj, null, 2)
        .replace(/("color": \{)([^}]+)/g, (_, a, b) => a + b.replace(/\s+/g, ' '));

console.log(str);