Enviar una matriz de objetos json a la acción con ajax en asp.net mvc 3
Espero que alguien me pueda ayudar (perdón por mi inglés). Tengo un problema cuando quiero enviar un array de arrays en ajax. Mi modelo es:
public class SJSonModel
{
public string Name { get; set; }
public bool isChecked { get; set; }
}
public class SJSonModelList
{
public List<SJSonModel> Features { get; set; }
public List<SJSonModel> MenuItems { get; set; }
}
El controlador:
[HttpPost]
public ActionResult CheckPreferences(SJSonModelList postData)
{
BindUserFeatures(postData.Features);
return Json(new { status = "Success", message = "Passed" });
}
La vista simplificada:
<div class="Feature borderRadius Items">
<h2>Title
<input type="checkbox" class="Item" name="featureName"/>
</h2>
<div class="FeatureDetails subItems">
<a href="@Url…">featureName</a>
<input type="checkbox" class="subItem" name="subItemName"/>
</div> <!-- endOf FeatureDetails -->
El código JQuery:
var isChecked = false;
var features = new Array();
var menuItems = new Array();
var postData = new Array();
Aquí lleno las características, los elementos de menú con la característica Nombre / menúItemaNombre e isChecked boolean para cada característica / menú Artículo
menuItems.push({ "Name": $(this).attr('name'), "isChecked": isChecked });
features.push({ "Name": $(this).attr('name'), "isChecked": isChecked });
postData.push({ "features": features, "menuItems": menuItems });
postData = JSON.stringify(postData);
La función ajax:
$(':submit').click(function () {
postData.push({ "features": features, "menuItems": menuItems });
postData = JSON.stringify(postData);
$.ajax({
url: '@Url.Action("CheckPreferences")',
type: 'POST',
data: postData,
contentType: "application/json; charset=utf-8",
dataType: "json",
traditional: true,
success: function () { window.alert('@Resource.AjaxSuccess'); },
error: function (event, request, settings) { window.alert('@Resource.AjaxError' + ' : ' + settings); },
timeout: 20000
}); //endOf $.ajax
}); //endOf :submit.click function
Cuando hago alerta (postData), en el lado del cliente contiene los valores reales para cada elemento, pero en el controlador los postData.Features y postData.MenuItems son nulos.
También he intentado pasar una matriz al controlador:
features = JSON.stringify(features);
en $ .ajax:
{… data: features,…}
en el controlador:
ActionResult CheckPreferences(IEnumerable<SJSonModel> features)
y funciona bien, pero no sé cómo pasar la matriz de objetos json a mi controlador. Así que espero recuperar la respuesta aquí :)
Muchas gracias.