MVC - 使用 JQuery 在主视图中触发局部视图的提交事件

MVC - Trigger submit event of partial view in main view using JQuery

我在局部视图中使用 Ajax.BeginForm 来提交数据。

局部视图 - _getCategoryMaster.cs

<div>
    @using (Ajax.BeginForm("Submit", "CategoryMasterDataEntry", new AjaxOptions { OnSuccess = "OnDatatSuccess", OnFailure = "OnDataFailure", HttpMethod = "POST" }, new { enctype = "multipart/form-data" }))
    {
           <div style="float:left;width:100%;">
                <hr class="horizontal-line-bottom" />
                <div class="form-buttons tab-footer">
                    <button class="btn btn-md" type="submit" id="saveData" @if (TempData["DisplayAccess"].ToString() == "view") { <text> disabled </text>  }>SAVE</button>
                </div>
            </div>
     }
</div>

现在,我正尝试从我的父视图调用此提交事件,以调用来自 Jquery

的 link 的点击事件

父视图 -

<html>
<head>
<script type="text/javascript">
 $(document).on('click', '.getProducts', function (e) {
        alert("Start");

        $('form#ajaxForm').trigger('submit');

        alert("End");
</script>
</head>
<body>
 <a id="anchId" href="javascript:void(0);" class="getProducts">
 <img src="~/Images/bullets.png" class="bullet-image" /> 
  <span class="menu-text">LinkName</span> 
  </a>
</body>
</html>

但它不会触发局部视图的提交事件。我收到这些警报(开始和结束)。但它没有触发该提交事件。

我做错了什么?

您没有 id="ajaxForm" 的表格。用 new { id= "ajaxForm" }

替换 new { enctype = "multipart/form-data" }(这是没有意义的,因为您不能使用 Ajax.BeginForm() 提交文件)
@using (Ajax.BeginForm("Submit", "...", new AjaxOptions { ... }, new { id = "ajaxForm" }))

或简单地使用$('form').trigger('submit');