通过JSON将对象数组发布到ASP.Net MVC3

通过JSON将对象数组发布到ASP.Net MVC3

我正在寻找一种通过JSON将对象数组发布到MVC3的解决方案。


我正在处理的示例代码为:http : //weblogs.asp.net/scottgu/archive/2010/07/27/introducing-asp-net-mvc-3-preview-1.aspx


JS:


var data = { ItemList: [ {Str: 'hi', Enabled: true} ], X: 1, Y: 2 };


$.ajax({

    url: '/list/save',

    data: JSON.stringify(data),

    success: success,

    error: error,

    type: 'POST',

    contentType: 'application/json, charset=utf-8',

    dataType: 'json'

});

ListViewModel.cs:


public class ListViewModel

{

    public List<ItemViewModel> ItemList { get; set; }

    public float X { get; set; }

    public float Y { get; set; }

}

ItemViewModel.cs:


public class ItemViewModel

{

    public string Str;   // originally posted with: { get; set; }

    public bool Enabled; // originally posted with: { get; set; }

}

ListController.cs:


public ActionResult Save(ListViewModel list)

{

    // Do something

}

POST的结果:


将list设置为ListViewModel。设置

其X和Y属性。设置

基础的ItemList属性

。ItemList包含一个项目,

该项目应为未初始化。Str为null,Enabled为false。


换句话说,这就是我从MVC3的模型绑定中得到的结果:


list.X == 1

list.Y == 2

list.ItemList != null

list.ItemList.Count == 1

list.ItemList[0] != null

list.ItemList[0].Str == null

MVC3 JsonValueProvider似乎不适用于复杂对象。我该如何工作?我是否需要修改现有的MVC3 JsonValueProvider并对其进行修复?如果是这样,我如何获得它并在MVC3项目中替换它?


我已经没有用过的相关StackOverflow问题:


Asp.net Mvc Ajax Json(后数组) 使用MVC2和较旧的基于表单的编码-这种方法对于包含对象数组的对象将失败(JQuery无法对其进行正确编码)。


使用JSON发布一系列复杂对象,JQuery到ASP.NET MVC Controller。 我想避免在Controller收到一个纯字符串的地方,然后由它手动反序列化自身,而不是利用框架,这是我想避免的。


MVC3 RC2 JSON发布绑定未正常工作 未设置他的内容类型-它在我的代码中设置。


如何使用JSON,jQuery将复杂对象数组发布到ASP.NET MVC Controller? 这个可怜的家伙不得不写一个JsonFilter只是为了解析一个数组。我宁愿避免的另一种攻击。


那么,我该如何实现呢?


小怪兽爱吃肉
浏览 713回答 4
4回答

慕田峪4524236

我有一个类似的问题,发现对于一个复杂的对象,数值会被遗漏。他们进来为零。即&nbsp; &nbsp; var person = {&nbsp; &nbsp; &nbsp; &nbsp; Name: "john",&nbsp; &nbsp; &nbsp; &nbsp; Age: 9&nbsp; &nbsp; }由MVC控制器作为Person对象接收,其中属性填充为Name=John和Age=0。然后,我将Javascript中的Age值设置为字符串...即&nbsp; &nbsp; var person = {&nbsp; &nbsp; &nbsp; &nbsp; Name: "john",&nbsp; &nbsp; &nbsp; &nbsp; Age: "9"&nbsp; &nbsp; }这样就好了...
打开App,查看更多内容
随时随地看视频慕课网APP