【问题标题】:How can I deserialize a json string without knowing the name of the fields?如何在不知道字段名称的情况下反序列化 json 字符串?
【发布时间】:2015-12-10 09:24:04
【问题描述】:

我有一个可以看起来像这样的字符串:

[  
   {  
      Id:{  
         editable:false,
         nullable:true
      }
   },
   {  
      Product:{  
         validation:{  
            required:true
         }
      }
   },
   {  
      Cost:{  
         type:"number",
         validation:{  
            required:true
         }
      }
   }
]

它也可以是这样的:

[  
   {  
      Id:{  
         editable:false,
         nullable:true
      }
   },
   {  
      Car:{  
         validation:{  
            required:true
         }
      }
   },
   {  
      Make:{  
         validation:{  
            required:true
         }
      }
   }
]

关键是字符串总是有一个带有一些可预测值的 Id 字段,但其他字段可以命名为任何东西。

我有一些 javascript,我需要看起来像这样:

schema: {
   model: {
      id: "Id",
      fields: {
          Id: { editable: false, nullable: true },
          Product: { validation: { required: true } },
          Cost: { type: "number", validation: { required: true }}
      }
   }
}

...字段的内容需要与字符串相关联。

目前我有一个 ajax 调用来获取我的代码需要的一些其他数据,我还想给它我需要的字段结果。我想像这样替换json:

schema: {
   model: {
      id: "Id",
      fields: ajaxResult.fields
      }
   }
}

正常的方法是创建一个类(或多个类),我可以将 json 字符串反序列化到该类,但在这种情况下,json 字符串中的字段可以是完全任意的。 所以我无法为此创建类,因为我不知道属性将被称为什么

我怎样才能反序列化这个字符串,以便当我从我的操作中返回它时,它会像我描述的那样工作?

目前我的控制器操作看起来像这样:

public IActionResult GetJsonData(Guid id)
{
   var model = new GridDataModel
   {
       schema = SchemaToJson(id),
       //fields = FieldsToJson(id),
       gridData = RowsToJson(id)
   };
   return Json(model);
}

【问题讨论】:

  • 你在使用 Json.Net 吗?
  • 格式化您的 JSON。您的 JSON 无效。
  • SchemaToJson()RowsToJson() 返回什么?
  • @timothyclifford 我想我几乎所有事情都在使用 Newtonsoft。其他两个函数返回 Json 我需要的其他没有相同问题的 JavaScript 代码区域(即,Json 定义明确并且具有非静态的字段排列)。
  • @RvdK Hrmm。好吧。我也通过验证器运行它,看到了你所看到的......但我几乎相同的 json 处理得很好。唯一的区别是我可以将其他 json 反序列化为实际的类(因为字段不会改变)。

标签: javascript c# json asp.net-core-mvc


【解决方案1】:

在 Visual Studio 2015 中,您可以使用“特殊粘贴”功能,Visual Studio 将为您生成所有类(包括嵌套类等),无需您自己编写一行代码:

请看下面的动画:(原始GIF来自here。)

【讨论】:

  • 这很酷......但似乎没有解决我的问题中的任何问题。所有这一切都是为了节省打字。打字不是我的问题。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-07-26
  • 2012-07-21
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多