使用JSON.NET将JSON反序列化为匿名对象

11

我正在使用JSON.NET来反序列化一个对象,但是我无法将其与我当前使用的对象结构配合使用。

http://dorobantu.me/post/2010/08/22/Deserializing-JSON-to-anonymous-types-in-C.aspx

我的对象目前看起来像这样(我想传递一个对象列表)

[
{
    "ID": "Concurrent User",
    "FieldType": 190,
    "value": ""
},
{
    "ID": "System Type",
    "FieldType": 191,
    "value": null
}
]

我遇到了以下错误:

Cannot deserialize JSON array into type '<>f__AnonymousType1`3[System.String,System.String,System.String]'.

我需要的是类似于示例#2的东西,一个包含列表的容器对象。非常感谢任何帮助。谢谢。

c# 代码:

public void GetPoints()
    {
        string inputFields = HttpContext.Current.Request["inputFields"];

       // var test =  new { ID = string.Empty, FieldType = string.Empty, Description = string.Empty };

        var example = new { containerArray = new { ID = string.Empty, FieldType = string.Empty, Description = string.Empty } };

        var fields = JsonConvert.DeserializeAnonymousType(inputFields, example);
    }

JavaScript:

$('.quoteonly :input').live('change keyup', function () {

        var $container = $('#quoteonly-container');
        var containerObject = {};

        var containerArray = [];

        $container.find('.quoteonly :input').each(function () {

            var fieldType = $(this).data('fieldtype');
            var id = $(this).data('id');

            var currentObject = { 'ID': id, 'FieldType': fieldType };

            switch (fieldType) {

                case 190: //textbox
                    currentObject.value = $(this).val();
                    break;
                case 191: //select
                    currentObject.value = $(this).val();
                    break;
                case 192: //radio
                    currentObject.value = $(this).prop('checked') == true ? 1 : 0;
                    break;
                case 193: //checkbox
                    currentObject.value = $(this).prop('checked') == true ? 1 : 0;
                    break;
            }

            containerArray.push(currentObject);
            containerObject.containerArray = containerArray;
        });

        $.ajax({
            url: '../SentinelOperationsUI/GenericHandler.ashx',
            data: { 'FunctionName': 'GetPoints', 'inputFields': JSON.stringify(containerObject) },
            success: function (data) {

            }
        });

    });

你能添加一些代码来获取上下文吗?首先是调用代码,然后是使用结果。 - Mharlin
1个回答

17
  • 1.

var DTO = { 'items': JSON.stringify(containerObject) };

将容器对象转换为JSON字符串并存储在DTO对象的items属性中。
$.ajax({
            url: '../SentinelOperationsUI/GenericHandler.ashx',
            data: JSON.stringify(DTO),
            success: function (data) {

            }
        });

如果您的代码中的输入字段字符串形式为 {items: [{..}]} 而不是 [{..}, {..}],则可以跳过此步骤。我添加了这个测试目的。重要的是要以这种格式获取字符串输入字段 [{..}, {..}]

  • 2.

.

 public void GetPoints()
        {
            string inputFields = HttpContext.Current.Request["items"];
            var test = new[] { new { ID = 0, FieldType = string.Empty, Description = string.Empty } };
            var fields = JsonConvert.DeserializeAnonymousType(inputFields, test);
        }

看起来是一个解决方案,虽然现在无法测试。不知道new[]部分。感谢您的帮助! - Johan

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接