I'm having difficulty posting a JavaScript object via jQuery to a .net MVC 3 controller.
My object:
var postData = {
'thing1' : "whatever",
'thing2' : "something else",
'thing3' : [1, 2, 3, 4]
}
My jQuery Call:
$.post('<%= Url.Action("Commit", "MassEdit") %>', postData, function (data) {
// stuff
});
My View Model:
public class SubmitThing {
public string thing1 { get; set; }
public string thing2 { get; set; }
public IEnumerable<int> thing3 { get; set; }
}
My controller:
[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Commit(SubmitThing changes)
{
return new EmptyResult();
}
The problem is that my 'changes' object that I have within my controller have thing1 equal to "whatever", thing2 equal to "something else", but thing3 is null. Now do I get thing3 to be my list of integers?
Added: I think this is more of a mapping issue than a serialization issue. In my controller, if I look at
HttpContext.Request.Form["thing3[]"]
I get a string with the value of "1,2,3,4". But again, I'd like the mapping to just work.
Thanks!
Just post it as json:
$.ajax({
url: '<%= Url.Action("Commit", "MassEdit") %>',
type: 'POST',
dataType: 'json',
data: JSON.stringify({'thing1' : "whatever",
'thing2' : "something else",
'thing3' : [1, 2, 3, 4]
}),
contentType: 'application/json; charset=utf-8',
success: function (data) {
}
});
and it should work
Hi why don't you join the values before passing them?
var thing3 = [1, 2, 3, 4];
thing3 = thing3.join(',');
var postData = {
'thing1' : "whatever",
'thing2' : "something else",
'thing3' : thing3
}
otherwise i think you have to use the $.ajax function to have it serialaize the array
I'm doing something similar in a web forms project, but I'm using List<int>
instead of IEnumberable<int>
(edit to add:) And it's working... ;)
EDIT 2 :
Looking farther at what we're doing different. Could you try building your object slightly differently and using JSON.stringify()
? The following is a bit closer to what's working for me...
var postData = JSON.stringify({
thing1 : "whatever",
thing2 : "something else",
thing3 : [1, 2, 3, 4]
});
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.