如何从Typescript

时间:2018-11-05 13:41:06

标签: json angular

我知道有很多关于如何从json获取密钥的线程,但是我没有找到我的具体情况。我的问题更令人毛骨悚然。 例如,考虑以下json:

 {
  "User": {
    "Username": "testuser",
    "Roles": ["Chief", "Other"],
    "Languages": ["it", "en"],
    "IsActive": true,
    "Family": {
        "Mother": "Mary",
        "Father": "Mike"
      }
  },
  "Timestamp": null
}

我需要获取所有嵌套键的列表,例如:

User.Usernames
User.Roles
User.Languages
User.IsActive
User.Family.Mother
User.Family.Father
Timestamp

不是

User
Usernames
Roles
Languages
IsActive
Family
Mother
Father
Timestamp

我不希望知道每个键的值。我无法使用该值搜索键,因为它可以每次更改。 代码:

Object.keys(myJson)

仅给我json的根元素(在本例中为“ User”和“ Timestamp”)。 我在Angular 6中使用打字稿2.9.2。

谢谢。

1 个答案:

答案 0 :(得分:2)

尝试一下:

let obj ={
  "User": {
    "Username": "testuser",
    "Roles": ["Chief", "Other"],
    "Languages": ["it", "en"],
    "IsActive": true,
    "Family": {
        "Mother": "Mary",
        "Father": "Mike"
      }
  },
  "Timestamp": null
}

var list = [];
getProps(obj);

function getProps(obj, parent=null) {
      for (var props in obj) {

          if (typeof (obj[props]) == "object" && obj[props] !== null && !Array.isArray(obj[props]) ) {
                 getProps(obj[props],props)
          }
          else if (parent !== null) {
                  list.push(parent+"."+props);
          }
          else {
                  list.push(props);
          }
        }
    }

 console.log(list);