在 JavaScript 中扁平化 JSON 对象


假设我们有一个 JSON 对象,它可能包含任意级别的嵌套 -

const obj = {
   "one": 1,
   "two": {
      "three": 3
   },
   "four": {
      "five": 5,
      "six": {
         "seven": 7
      },
      "eight": 8
   },
   "nine": 9
};

我们需要编写一个 JavaScript 函数,它采用一个这样的嵌套 JSON 对象,并返回一个不包含嵌套并使用点符号将相应的值映射到键的新对象。

因此,对于上面的对象,输出应该类似于这样 -

const output = {
   'one': 1,
   'two.three': 3,
   'four.five': 5,
   'four.six.seven': 7,
   'four.eight': 8,
   'nine': 9
};

示例

代码如下 -

 Live Demo

const obj = {
   "one": 1,
   "two": {
      "three": 3
   },
   "four": {
      "five": 5,
      "six": {
         "seven": 7
      },
      "eight": 8
   },
   "nine": 9
};
const flattenJSON = (obj = {}, res = {}, extraKey = '') => {
   for(key in obj){
      if(typeof obj[key] !== 'object'){
         res[extraKey + key] = obj[key];
      }else{
         flattenJSON(obj[key], res, `${extraKey}${key}.`);
      };
   };
   return res;
};
console.log(flattenJSON(obj));

输出

而控制台中的输出将为 -

{
   one: 1,
   'two.three': 3,
   'four.five': 5,
   'four.six.seven': 7,
   'four.eight': 8,
   nine: 9
}

更新于: 2021 年 2 月 22 日

12K+ 次浏览

开启职业生涯 征程

完成该课程以获得认证

开始学习
广告
© . All rights reserved.