Bonjour,
J’ai un problème en passant à l’action un array des arrays en ajax :
Model :
Controller :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11 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; } }
View (simplifié, j’ai enlevé les infos dynamiques):
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7 [HttpPost] public ActionResult CheckPreferences(SJSonModelList postData) { BindUserFeatures(postData.Features); return Json(new { status = "Success", message = "Passed" }); }
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11 <div class="Feature borderRadius Items"> <h2>Title <input type="checkbox" class="Item" name="featureName"/> </h2> <img src="url" alt="" /> <div class="FeatureDetails subItems"> <a href="@Url ">featureName</a> <input type="checkbox" class="subItem" name="subItemName"/> </div> <!-- endOf FeatureDetails --> </div> <!-- endOf Feature -->
Code JQuery :
{ici je remplis les features, menuItems et je donne une valeur au isChecked selon les checkbox cochés/décochés }
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5 var isChecked = false; var features = new Array(); var menuItems = new Array(); var postData = new Array();
partie ajax :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5 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);
Côté client quand je fait alert(postData), il contient bien les données cochées / décochées avec les bonnes valeurs de isCheched pour chacun mais côté controlleur la valeur de Features et de MenuItems est null à chaque fois, alors que quand je passe juste l’un des arrays au controlleur :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 $(':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
Ex :
dans ajax :
Code : Sélectionner tout - Visualiser dans une fenêtre à part features = JSON.stringify(features);
Et dans controlleur :
Code : Sélectionner tout - Visualiser dans une fenêtre à part { data: features, }Tout marche très bien.
Code : Sélectionner tout - Visualiser dans une fenêtre à part ActionResult CheckPreferences(IEnumerable<SJSonModel> features)
Est-ce que quelqu'un voit où est le problème?
Merci d’avance.
Partager