1

我对 MVC 和 JQuery 还很陌生。我正在使用 MVC 4。我有一个可以编辑字段的索引视图。我希望能够在列表底部添加一个空白行,用于添加新行。到目前为止,我的工作基于 MVC 2 中的这个示例:http: //blog.stevensanderson.com/2010/01/28/editing-a-variable-length-list-aspnet-mvc-2-style/

这是我的索引视图:

    @using (Html.BeginForm()) {
<h3 style="margin-top: 1px;">
    <input type="hidden" name="selectedConditionID" value="@ViewBag.SelectedConditionID" />
    <input type="hidden" name="isCore" />
    <input type="submit" value="Save" />
    @Html.ActionLink("Add Condition Detail", "BlankEditorRow", null, new { id="addItem"})
</h3>
<div class="table" id="editorRows"> 
@for (var i = 0; i < Model.Count; ++i) {
    ViewBag.i = i;
    Html.RenderPartial("_ConditionDetailEditorRow", Model[i]);
}
</div>
<div>
    @Html.ActionLink("Back to Condition Library", null, "Home")
</div>

}

这是部分视图:

    <div class="editorRow">
@if (@ViewBag.i == 0) {
    <div class="header-row">
        <div class="header-cell">@Html.DisplayNameFor(model => model.StackRank)</div>
        <div class="header-cell">@Html.DisplayNameFor(model => model.ID)</div> ...
        <div class="header-cell">Options</div>
    </div>
}

@using (Html.BeginForm()) {
    @Html.ValidationSummary(true)
    int i = @ViewBag.i;
    <div  class="body-cell">
        @Html.TextBoxFor(m => m.StackRank)
        @Html.ValidationMessageFor(m => m.StackRank)
    </div>
    <div  class="body-cell">
        @Html.DisplayFor(m => m.ID)
    </div> ...
    <div  class="body-cell">
        @Html.ActionLink("Edit", "Edit", new { id=Model.ID }) |
        @Html.ActionLink("Delete", "Delete", new { id=Model.ID })
    </div>
}

这是我的索引视图中的 JQuery,它应该导致将空白行添加到索引列表的末尾:

$(function () {
    $("#addItem").click(function () {
        $.ajax({
            url: this.href,
            cache: false,
            success: function (html) { $("#editorRows").append(html); }
        });
        return false;
    });
});

这是控制器方法:

public PartialViewResult BlankEditorRow()
    {
        ViewBag.i = 0;
        return PartialView("_ConditionDetailEditorRow", new Condition_Details());
    }

这是问题所在:当我单击索引页面上的“添加条件详细信息”操作链接时,我只得到一个部分视图的页面(...//localhost:56213/ConfigurationUI/ConditionDetails/BlankEditorRow/addItem)。

我想要的是在索引页面底部出现一个空白行。我假设 URL 应该类似于:...//localhost:56213/ConfigurationUI/ConditionDetails/Index/addItem。

现在我怀疑我的 JQuery 脚本没有触发,但不知道为什么?

怎么了?

谢谢!

我想出了一个解决方案:

我把整个表放在局部视图中:

修订的索引视图

<div id="condition_detailsList">
     @{ Html.RenderPartial("_ConditionDetailsEdit", Model); }
</div>        

修订的局部视图

<table id="condition_detailsList">
<thead>
    <tr>
        <th>
            @Html.DisplayNameFor(model => model[0].StackRank)
        </th>...

    </tr>
    </thead>
    <tbody id="editorRows">
        @for (var i = 0; i < Model.Count; ++i) {
            <tr style="margin:0; padding:0; border:0;">
                <td> <div>
                    @Html.TextBoxFor(m => m[i].StackRank)
                    @Html.ValidationMessageFor(m => m[i].StackRank)
                </div> </td>...

            </tr>
                @Html.HiddenFor(m => m[i].ID, new { @id = "hID" + i })...
        }
</tbody>

从使用 Ajax 的 Index 视图中,我在控制器中调用了 post 方法

    $(function () {
    $('#addItem').click(function () {
        $.ajax({
            cache: false,
            type: "POST",
            url: "@(Url.Action("GetNewRow", "ConditionDetails"))",
            data: { "conditionID": cID },
            success: function (condition_detailsListPlusNewRow) {
                //initialize fields...

在控制器中,我将新行返回到局部视图

[HttpPost]
    public ActionResult GetNewRow(int conditionID) //, List<Condition_Details> conditionDetails)
    {
        //you must initial the index view here, then...

        //retrieve the list, add a new row and return the partial view
        var condition_details = db.Condition_Details.Where(x => x.Condition_ID ==       conditionID).OrderBy(x => x.StackRank).ThenBy(x => x.ID).ToList();

        Condition_Details conditionDetail = new Condition_Details();
        List<Condition_Details> condition_detailsPlusNewRow = new List<Condition_Details>();
        foreach (var row in condition_details)
        {
            conditionDetail = row;
            condition_detailsPlusNewRow.Add(conditionDetail);
        }

        Condition_Details newRow = new Condition_Details();
        newRow.Condition_ID = conditionDetail.Condition_ID;
        newRow.Condition = conditionDetail.Condition;
        newRow.StackRank = conditionDetail.StackRank + 1;
        condition_detailsPlusNewRow.Add(newRow);


        return PartialView("_ConditionDetailsEdit", condition_detailsPlusNewRow);
    }
4

0 回答 0