将数据从 jQueryUI 对话框窗体传递到控制器



我是 ASP.NET/Javascript 新手,在使用jQueryUI对话框表单实现简单的CRUD操作时遇到了一些麻烦。这是我的代码:

<button class="update" id="@Model.id">Update</button>
<div id="dialog-form" title="Update">
  <form>
    <fieldset>
      <input type="text" name="state" id="state">
      <input type="text" name="note" id="note">
      <input type="submit">
    </fieldset>
  </form>
</div>
<script>
      $(function() {
          var dialog,
            state = $("#state"),
            note = $("#note"),
            id = this.id, //??
            dialog = $("#dialog-form").dialog({
              autoOpen: false,
              height: 400,
              width: 350,
              modal: true,
              buttons: {
                "Ok": function() {
                  $.ajax({
                    type: "POST",
                    url: "@Url.Action("Update","Ticket")",
                    data: {
                      id: id,
                      state: state,
                      note: note
                    },
                    cache: false,
                    dataType: "json",
                    success: function(data) {
                      $("#dialog").dialog("close");
                    }
                  });
                },
                "Cancel": function() {
                  $(this).dialog("close");
                }
              }
            });
          $(".update").button().on("click", function() {
            dialog.dialog("open");
          });
        });
</script>    

最后是TicketController中的Update动作:

  public ActionResult Update(String id, String state, String note)
    {
        //do some stuff
    }

但是,什么也没发生,它不会进入行动。任何帮助都非常感谢

更改data如下所示,您需要使用 .val(( 传递值而不是对象

state = $("#state").val(),
note = $("#note").val(),
id = "Pass anything you wants"
data: { 'id':id,'state':state,'note':note },

[HttpPost]装饰您的操作方法

[HttpPost]
public ActionResult Update(String id, String state, String note)
{
}

最新更新