HTML.BeginForm / Ajax.Begin表单在部分视图中不起作用

时间:2016-06-28 09:49:57

标签: jquery asp.net-mvc asp.net-mvc-partialview html.beginform

我有一个部分视图,其中包含表和数据动态附加到该表。当我单击该窗体中的“保存”按钮时,我的控制器方法未触发。

请参阅以下代码以了解我的部分视图。

 <div id="cavitypartial">
 <table id="CTable" class=" table table-bordered">
    <tr>
        <th></th>
        <th>C Name</th>
        <th>Number of C</th>

        @foreach (var item in Model.PLByS)
            {
            <th>@item.PLName (CT/sec)</th>
            }
        <th>Comments</th>
    </tr>
    @foreach (var item in Model.CByS)
        {
            //using (Html.BeginForm("CavityUpdate", "Cavity", FormMethod.Post, new { id = "tblCavity" }))
            using (Ajax.BeginForm("CavityUpdate", "Cavity", new AjaxOptions { HttpMethod = "POST", InsertionMode = InsertionMode.Replace, UpdateTargetId = "cavitypartial" }))
            {


                <tr id="@item.CavityID">

                    <td><a onclick='DeleteRow(this,@item.CavityID);'><img src='/Content/Images/trash_empty.png' class='btndelete' alt='x' /></a><a onclick='EditRow(this,@item.CavityID);'><img src='~/Content/Images/edit.png' class='btndelete' alt='x' /></a></td>
                    <td><input type="text" id="cn_@item.CavityID" name="cn_@item.CavityID" value="@item.CavityName" disabled /></td>
                    <td><input type="text" id="cp_@item.CavityID" name="cp_@item.CavityID" class="addcavity" value="@item.NumberOfParts" disabled /> <input type="hidden" id="h_@item.CavityID" name="h_@item.CavityID" /> </td>
                    @foreach (var Cavitem in Model.Cavities)
                    {
                        if (item.CavityID == Cavitem.CavityID)
                        {
                            <td><input type="text" id="c_@(item.CavityID)p_@(Cavitem.ProductLineID)" name="c_@(item.CavityID)p_@(Cavitem.ProductLineID)" class="addcavity" value="@Cavitem.Time" disabled /></td>
                        }

                    }
                    <td><input type="text" id="cn_@item.CavityID" name="cc_@item.CavityID" value="@item.comments" disabled /> <input type="hidden" id="h_@item.CavityID" name="h_@item.CavityID" /> </td>
                    <td id="Savecommand"><input type="submit" id="btnS_@item.CavityID" value="Save" /></td>
                    <td id="Savecommand"><input type="button" id="btnC_@item.CavityID" onclick="cancelEditing(this,@item.CavityID);" value="Cancel" /></td>


                </tr>
            }
        }
</table>
</div>

以下是渲染部分视图的主页面

<div id="cavitypartial">
@Html.Partial("CavityPartialView")

</div>

我不使用除此之外的任何其他形式。

以下是控制器代码:

   [HttpPost]
    public ActionResult CavityUpdate()
    {
        // logic

        }

        return RedirectToAction("Cavity", "Cavity", new { id = siteid });


    }

有人可以帮我吗?

2 个答案:

答案 0 :(得分:1)

最后,我的控制器方法是从部分View中触发。我做的错误是,我把Html.Begin表格放在div标签里面。我将它移到了外面并在BeginForm下放置了整个partail视图。

现在工作正常。

答案 1 :(得分:0)

启用提交按钮。从中移除“禁用”属性。

编辑: 您不能将表单元素创建为表行。而是尝试以下语法:

<table>
        @foreach (var item in Model.CByS) { 
        <tr>
            <td>
                @using(Ajax.BeginForm("CavityUpdate", "Cavity", new AjaxOptions { HttpMethod = "POST", InsertionMode = InsertionMode.Replace, UpdateTargetId = "cavitypartial" })){
                    //your code
                    <table>
                        <tr>
                            <td></td>
                        </tr>
                    </table>
                }
            </td>
        </tr>
        }
    </table>