Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Passing Javascript array to ASP.NET MVC Controller

I have the following javascript class which I am trying to pass to an ASP.NET MVC Controller

 var postParams = {

         attributes : [
                         {
                            name : '',
                            description: '',
                            attributeType : '',
                            value : ''
                        }
                      ]
    };

 postParams.attributes[0] = new Object();
 postParams.attributes[0].name = "test";
 postParams.attributes[0].description = "test";
 postParams.attributes[0].attributeType = "test";
 postParams.attributes[0].value = "test";

Here's how I call the Controller method:

  var actionURL = "@Url.Action("Save", "Catalog")";
  $.ajax({
                    type: "POST",
                    url: actionURL,
                    data:  postParams   ......

On the Controller side I've declared a ViewModel as follows:

 public class AttributeViewModel
 {
    public string name { get; set; }
    public string description { get; set; }
    public string attributeType { get; set; }
    public string value { get; set; } 
 }

My Controller Save method is declared as follows:

 public JsonResult Save(AttributeViewModel[] attributes)

When I execute the value of attributes is always null.

Any ideas? Not sure how to even start debugging this.

like image 881
Lance Avatar asked Apr 06 '12 11:04

Lance


2 Answers

You can try json.net library to solve your issue

  [JsonFilter(Param = "attributes", JsonDataType = typeof(AttributeViewModel[]))]
  public JsonResult Save(AttributeViewModel[] attributes)

At client:

$.ajax({
        type: 'POST',
        url: url,
        async: true,
        data:  JSON.stringify(attributes), //!!! Here must be the same name as in controller method
        dataType: 'json',
        contentType: 'application/json; charset=utf-8',
        success: function (data) {

        },
        error: function (xhr, ajaxOptions, thrownError) {

        }
    });
like image 160
Sanja Melnichuk Avatar answered Oct 06 '22 23:10

Sanja Melnichuk


Seems like you need to add traditional : true to the ajax call. Take a look here and here

 $.ajax({ 
                traditional: true,
                type: "POST", 
                url: actionURL, 
                data:  postParams   
like image 25
huysentruitw Avatar answered Oct 06 '22 23:10

huysentruitw