weixin_42736674 2022-01-13 14:02 采纳率: 50%
浏览 85
已结题

实现一个方法flatten,将对象扁平化

问题遇到的现象和发生背景
问题相关代码,请勿粘贴截图
运行结果及报错内容
我的解答思路和尝试过的方法
我想要达到的结果
function flatten(obj) {
  // 你的代码
}


// 最终效果是执行
flatten({
  a: {
    b: 1,
    c: 2,
    d: {e: 5}
  },
  b: [1, 3, {a: 2, b: 3}],
  c: 3
}) 

// 得到
{
  'a.b': 1,
  'a.c': 2,
  'a.d.e': 5,
  'b[0]': 1,
  'b[1]': 3,
  'b[2].a': 2,
  'b[2].b': 3'c': 3
}          

  • 写回答

1条回答 默认 最新

  • 原莱_ 2022-01-13 17:33
    关注
    var comType=['object','array'];
    let o = {
      a: {
        b: 1,
        c: 2,
        d: {e: 5}
      },
      b: [1, 3, {a: 2, b: 3}],
      c: 3
    }
    var flatten = function(o,prekey,resobj){
        prekey=prekey?prekey+'.':'';
        var keys=Object.keys(o);
        keys.forEach(function(item){
          var v=o[item];
          var type=typeof v;
          if(v && comType.indexOf(type) != -1){
            flatten(v,prekey+item,resobj);
          }else{
            resobj[prekey+item]=v;
          }
        })
     }
     var result={};
     flatten(o,'',result);
     console.log(result);
    

    对你有用的话,请点下采纳,谢谢

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 1月22日
  • 已采纳回答 1月14日
  • 创建了问题 1月13日

悬赏问题

  • ¥20 c语言写的8051单片机存储器mt29的模块程序
  • ¥60 求直线方程 使平面上n个点在直线同侧并且距离总和最小
  • ¥50 java算法,给定试题的难度数量(简单,普通,困难),和试题类型数量(单选,多选,判断),以及题库中各种类型的题有多少道,求能否随机抽题。
  • ¥50 rk3588板端推理
  • ¥250 opencv怎么去掉 数字0中间的斜杠。
  • ¥15 这种情况的伯德图和奈奎斯特曲线怎么分析?
  • ¥250 paddleocr带斜线的0很容易识别成9
  • ¥15 电子档案元素采集(tiff及PDF扫描图片)
  • ¥15 flink-sql-connector-rabbitmq使用
  • ¥15 zynq7015,PCIE读写延时偏大