首页 > 解决方案 > 删除嵌套的 JavaScript 对象

问题描述

我一直在尝试从 JavaScript 对象中删除嵌套对象,但没有成功,并且无法通过搜索以前的帖子找到正确的答案。

这是我一直在尝试做的事情。

<code id='code'></code>

var myobj = {
  "children": [
    {
      "name": "albuterol ",
      "children": [
        {
          "name": "albuterol  - fluticasone ",
          "children": [
            {
              "name": "prednisone ",
              "children": [
                {
                  "name": "dexamethasone ",
                  "children": [],
                  "size": 1,
                  "colname": "CONCEPT_NAME.4"
                }
              ],
              "size": 3,
              "colname": "CONCEPT_NAME.3"
            }
          ],
          "size": 4,
          "colname": "CONCEPT_NAME.2"
        }]}]} 

function deleteObject(myobj) {
    var x = delete myobj.colname
    return (myobj.name, myobj.children)
}

document.getElementById('code').innerText = JSON.stringify(deleteObject(myobj))

我想删除对象colname。我错过了什么还是代码完全不正确?

标签: javascript

解决方案


您需要一个递归函数来删除该属性。

var myobj = {
  "children": [
    {
      "name": "albuterol ",
      "children": [
        {
          "name": "albuterol  - fluticasone ",
          "children": [
            {
              "name": "prednisone ",
              "children": [
                {
                  "name": "dexamethasone ",
                  "children": [],
                  "size": 1,
                  "colname": "CONCEPT_NAME.4"
                }
              ],
              "size": 3,
              "colname": "CONCEPT_NAME.3"
            }
          ],
          "size": 4,
          "colname": "CONCEPT_NAME.2"
        }]}]} 

function deleteColnameRecursive(obj){
  delete obj.colname
  if(obj.children){
     for(var i=0;i<obj.children.length;i++)
         deleteColnameRecursive(obj.children[i]);
  }
}

deleteColnameRecursive(myobj);

console.log(myobj);


推荐阅读