javascript-使用lodash显示嵌套json的所有值

前端之家收集整理的这篇文章主要介绍了javascript-使用lodash显示嵌套json的所有值 前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我正在尝试使用lodash显示我拥有的JSON的所有值,就我所知,它最适合这种情况,如您所见,json很深,某些类别为空,这对我来说更具挑战性,我想知道哪个函数最适合显示这样的非结构化和深层JSON.是foreach还是filter? Lodash是这里最好的选择吗?数据最终将显示在react应用程序中,但现在我正在尝试进行映射/ foreach /过滤器或可以动态遍历所有项目的任何内容.

预期的输出是列表项嵌套树. >

{

  "name": "Menu","children": [
    {
      "type": "category","name": "Burgers","children": [
        {
          "type": "item","name": "Burger 1","children": [
            {
              "type": "modifier","name": "Promo","children": [
                {
                  "type": "item","name": "Promo 1"
                }
              ]
            },{
              "type": "group","name": "Drinks","name": "Coke"
                },{
                  "type": "item","name": "Light Coke"
                },"name": "Sprite"
                },"name": "Fanta"
                }
              ]
            },{
              "type": "modifier","name": "Without","children": [
                {
                  "type": "ingredient","name": "Onion"
                },{
                  "type": "ingredient","name": "Tomato"
                },"name": "Pickles"
                }
              ]
            }
          ]
        },{
          "type": "item","name": "Burger 2","name": "Coming Soon Offers"
        }
      ]
    },{
      "type": "category","name": "Pizzas","name": "Pizza 1","name": "Mashrooms"
                },"name": "Olives"
                }
              ]
            }
          ]
        },"name": "Pizza 2","name": "Olives"
                }
              ]
            }
          ]
        }
      ]
    }
  ]
}
最佳答案
只要您处理了未知深度的数据,就应该使用递归.

let obj = {
  "name": "Menu","name": "Olives"
                }
              ]
            }
          ]
        }
      ]
    }
  ]
}
let body = document.querySelector('body');
function print(obj){
  let str = `<li>${obj.name}</li>`;
  if(obj.children){
    str += '<ul>' 
    for(let c of obj.children) str += print(c)
    str += '</ul>'
  }
  return str;
}
document.body.innerHTML = print(obj);

猜你在找的JavaScript相关文章