javascript - 将数据从 jQueryUI 对话框表单传递到 Controller

标签 javascript jquery asp.net asp.net-mvc jquery-ui

我是 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
    }

然而什么也没有发生,它也没有进入行动。非常感谢任何帮助

最佳答案

更改您的数据,如下所示,您需要使用.val() 传递值而不是对象。

state = $("#state").val(),
note = $("#note").val(),
id = "Pass anything you wants"

data: { 'id':id,'state':state,'note':note },

[HttpPost]装饰你的action方法

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

关于javascript - 将数据从 jQueryUI 对话框表单传递到 Controller ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43066700/

相关文章:

javascript - Angular 应用程序没有被引导?

javascript - CakePHP 3 : Ajax response is returning a 200 response code and a parsererror

javascript - 如何使用条件运算符

jquery - 如何使用 jQuery 验证 Selectize.js 标签?

c# - 我的面板无法显示用户是否单击特定的下拉列表项

javascript - 使用 POLY LINE 时如何在 Google Map Javascript API 中显示旅行方向箭头?

jquery - 在同一动画中将 DIV 居中并放大?

jquery - 定义动态表格行颜色

asp.net - .NET Ionic.Zip : Compressed or Uncompressed size, 或偏移量超过最大值

asp.net - 在 Linux 机器上安装 Visual Studio