6

I have this in the controller:

[HttpPost]
    public ActionResult Create(Student student)
    { //somecode..

and i want to submit this from:

<form method="post" action="/student/create"> 
<!-- the from contents-->

how to submit this from using Ajax call i need the JQuery ajax call that lets this form submitted.

and i want to make sure about datatype , thanks

4

3 回答 3

18

尝试这个

var form = $('#formId');
$.ajax({
  cache: false,
  async: true,
  type: "POST",
  url: form.attr('action'),
  data: form.serialize(),
  success: function (data) {
    alert(data);
 }
});
于 2013-11-12T08:23:28.677 回答
5

假设您使用的是剃刀视图,请使用它:

@using (Ajax.BeginForm(new AjaxOptions(){
HttpMethod = "POST",
    Url = "your controller",
    OnComplete = "some client event"
})
{
    <fieldset>
        <legend>This is a demo form.</legend>
        @Html.LabelFor(model => model.Name)
        @Html.TextBoxFor(model => model.Name)

        <input type="submit" value="Save" />
    </fieldset>
}
于 2013-11-12T08:30:17.720 回答
1

好吧,它看起来像(不查看您的视图绑定):

// serialize your form into JSON - maybe you have a different method of doing it
var serializedForm = $("#YourFormId").serialize();

// post it to the server
$.post("/student/create", serializedForm)
    .done(function (response) { 
       // it's done
    })
    .fail(function (xhr, status, error) { 
       // something bad happened
    });
于 2013-11-12T08:22:44.117 回答