【问题标题】:Json data to typescript modelJson 数据到打字稿模型
【发布时间】:2023-03-10 08:35:01
【问题描述】:

我有一个 json 文件,我想创建模型以使用数据列表(部门编号和名称)进行自动完成,我找到了 json2ts.com 站点,但它不再工作了。 可以举个例子吗?

{
    "regions": {
        "alsace": [67, 68],
        "aquitaine": [40, 47, 33, 24, 64],
        "auvergne": [43, 3, 15, 63],
        "basse-normandie": [14, 61, 50],
        "bourgogne": [21, 58, 71, 89],
        "bretagne": [29, 35, 22, 56],
        "centre": [45, 37, 41, 28, 36, 18],
        "champagne-ardenne": [10, 8, 52, 51],
        "corse": ["2b", "2a"],
        "franche-compte": [39, 25, 70, 90],
        "haute-normandie": [27, 76],
        "languedoc-roussillon": [48, 30, 34, 11, 66],
        "limousin": [19, 23, 87],
        "lorraine": [55, 54, 57, 88],
        "midi-pyrennees": [46, 32, 31, 12, 9, 65, 81, 82],
        "nord-pas-de-calais": [62, 59],
        "pays-de-la-loire": [49, 44, 72, 53, 85],
        "picardie": [2, 60, 80],
        "poitou-charentes": [17, 16, 86, 79],
        "provences-alpes-cote-dazur": [4, 5, 6, 13, 84, 83],
        "rhones-alpes": [38, 42, 26, 7, 1, 74, 73, 69],
        "ile-de-france": [77, 75, 78, 93, 92, 91, 95, 94]
    },
    "departments": {
        "2a": {
            "name": "Corse-du-Sud",
            "formatted_name": "corse-du-sud"
        },
        "2b": {
            "name": "Haute-Corse",
            "formatted_name": "haute-corse"
        },
        "01": {
            "name": "Ain",
            "formatted_name": "ain"
        },
        "02": {
            "name": "Aisne",
            "formatted_name": "aisne"
        },
        "03": {
            "name": "Allier",
            "formatted_name": "allier"
        },
     ...
}

你能给我一个建议吗? 至少对部门来说。 在这种情况下创建接口或类更好吗? 谢谢。

【问题讨论】:

  • Ajay 回答中提到的其中一个 VSCode 插件可在线试驾:jsontots.com
  • 我注意到您是 SO 的新手 - 欢迎!如果您认为答案正确回答了您的问题,请考虑“接受”答案(通过单击复选标记)。

标签: javascript json angular typescript


【解决方案1】:

对于地区,您可以将此界面与您当前的数据一起使用:

interface Regions {
 [name: string]: number[];
}

这将为一个可以有任何字符串作为键的对象创建一个接口,并且每个属性的值必须是一个数字数组(您在上述对象中的“区域”属性与此描述相符)。

对于部门,我建议将其分成两个界面,如下所示:

interface Departments {
  [id: string]: Department;
}

interface Department {
  name: string;
  formatted_name: string;
}

现在“departments”对象的每个成员都可以有任何键,只要它是一个字符串,并且必须附加到一个部门。看起来您的数据要求每个部门都有一个名称和一个 formatted_name(不多也不少),我在上面的界面 Department 中表示了这一点。

那么您的整个对象将如下所示:

interface WholeThing {
  regions: Regions;
  departments: Departments;
}

【讨论】:

    【解决方案2】:

    对于 VScode IDE(Angular Dev 的首选 IDE),我建议您添加提供将 JSON 转换为 Typescript 的功能的插件。可能的解决方案可以是JSON to TSJSON to Type

    希望对你有帮助。

    【讨论】:

    • 太好了,一个新的解决方案
    猜你喜欢
    • 2023-03-07
    • 2018-11-09
    • 2022-11-19
    • 1970-01-01
    • 2022-12-05
    • 2021-01-26
    • 2018-02-06
    • 2017-01-20
    • 1970-01-01
    相关资源
    最近更新 更多