将JSON对象转换为C#列表

本文关键字:列表 转换 JSON 对象 | 更新日期: 2023-09-27 17:59:18

在发布这个问题之前,我尝试了其他相关的帖子,但没有成功,所以在这里发布。

我有一个Json存储在一个隐藏的字段中,我正在标记页面的代码隐藏文件中访问该字段。我需要将这个Json转换为List并将其绑定到一个网格,但在反序列化时,它会抛出一个错误,称为"Unexpected error encountered while parsing values ''"

用于从网格中获取数据并生成Json对象的脚本。

function BeforeSorting() {
    var list = UpdateDataSource();
    $("#SortingField").val(list);
}
function UpdateDataSource() {
    var list="";
    var grid = $find("DetailsGrid");
    var rows = grid.get_rows();
    for(var i =0 ; i<rows.get_length();i++){
        var name = rows.get_row(i).get_cellByColumnKey("Name").get_value();
        var country = rows.get_row(i).get_cellByColumnKey("Country").get_value();
        var gender = rows.get_row(i).get_cellByColumnKey("Gender").get_value();
        var age = rows.get_row(i).get_cellByColumnKey("Age").get_value();
        var uniqueKey = rows.get_row(i).get_cellByColumnKey("UniqueKey").get_value();
        list = list + '{"Name":"' + name + '", "Country":"' + country + '", "Gender":"' + gender + '", "Age":' + age + ', "UniqueKey":' + uniqueKey + '},';
    }
    list = "["+list.substr(0, list.length - 1)+"]";
    return JSON.parse(list);
}

型号类别:

public class Details
{
    public string Name { get; set; }
    public string Gender { get; set; }
    public string Country { get; set; }
    public int UniqueKey { get; set; }
    public int Age { get; set; }
}

用于反序列化json并将数据检索为模型类列表的代码。

protected void DetailsGrid_ColumnSorted(object sender, Infragistics.Web.UI.GridControls.SortingEventArgs e)
{
    var dataSource = SortingField.Value;
    List<Details> result = (List<Details>)Newtonsoft.Json.JsonConvert.DeserializeObject(dataSource, typeof(List<Details>));
    DetailsGrid.DataSource = result;
    DetailsGrid.DataBind();
}

获得的json字符串:

"[{"Name":"Jerry", "Country":"U.S.A.", "Gender":"Male", "Age":20, "UniqueKey":1},{"Name":"Tom", "Country":"U.K", "Gender":"Male", "Age":10, "UniqueKey":2},{"Name":"George", "Country":"Gremany", "Gender":"Male", "Age":38, "UniqueKey":3},{"Name":"Kate", "Country":"France", "Gender":"Female", "Age":40, "UniqueKey":4},{"Name":"Jenny", "Country":"Poland", "Gender":"Female", "Age":25, "UniqueKey":5}]"

将JSON对象转换为C#列表

list创建为数组,并将项添加为JavaScript对象,然后使用JSON.stringify 将其转换为JSON

function UpdateDataSource() {        
    var grid = $find("DetailsGrid");
    var rows = grid.get_rows();
    var list = [];
    for(var i =0 ; i < rows.get_length(); i++){
        var item = {
            Name : rows.get_row(i).get_cellByColumnKey("Name").get_value(),
            Country : rows.get_row(i).get_cellByColumnKey("Country").get_value(),
            Gender : rows.get_row(i).get_cellByColumnKey("Gender").get_value(),
            Age : rows.get_row(i).get_cellByColumnKey("Age").get_value(),
            UniqueKey : rows.get_row(i).get_cellByColumnKey("UniqueKey").get_value()
        };
        list.push(item);
    }
    return JSON.stringify(list);
}

用于对json进行反序列化并将数据检索为模型类列表的代码可以重构为

protected void DetailsGrid_ColumnSorted(object sender, Infragistics.Web.UI.GridControls.SortingEventArgs e) {
    var dataSource = SortingField.Value;
    var result = Newtonsoft.Json.JsonConvert.DeserializeObject<List<Details>>(dataSource);
    DetailsGrid.DataSource = result;
    DetailsGrid.DataBind();
}

@Adnreas建议的更新应该会产生相同的结果。

function UpdateDataSource() {        
    var grid = $find("DetailsGrid");
    var rows = grid.get_rows();
    var list = rows.map(function(row) {
        return {
            Name: row.get_cellByColumnKey("Name").get_value(),
            Country: row.get_cellByColumnKey("Country").get_value(),
            Gender: row.get_cellByColumnKey("Gender").get_value(),
            Age: row.get_cellByColumnKey("Age").get_value(),
            UniqueKey: row.get_cellByColumnKey("UniqueKey").get_value()
        };
    });
    return JSON.stringify(list);
}

我认为这将完成

protected void DetailsGrid_ColumnSorted(object sender, Infragistics.Web.UI.GridControls.SortingEventArgs e)
{
    var dataSource = SortingField.Value;
    List<Details> result = Newtonsoft.Json.JsonConvert.DeserializeObject<List<Details>>(dataSource);
    DetailsGrid.DataSource = result;
    DetailsGrid.DataBind();
}