1

主页 -> 第 1 部分(有一些下拉菜单和保存按钮)

        <div id="tab-section1">
            @{Html.RenderPartial("_Section1", Model.Section1);}
        </div>
        <div id="tab-section2">
            <div id="section2">
                @{Html.RenderPartial("_Section2", Model.Section2);}
            </div>
            @{Html.RenderPartial("_SubSection2", Model.SubSection2);}
        </div>

第 1 部分的内容放置在带有 @Html.BeginForm 的局部视图中。并使用@Html.RenderPartial 在主视图上呈现

@using MyData
@model Section1ViewModel
@using(Html.BeginForm("EditSection1", "Project", FormMethod.Post, new { id = "section1-form", name = "section-form" }))
{
    @Html.HiddenFor(model => model.ProjectID)
 <table id="modules">
        <tr>
            <td class="bold" colspan="2">Modules
            </td>
        </tr>
        <tr>
            <td>
                @Html.DropDownListFor(m => m.SubmittedModules, new MultiSelectList(Model.AvailableModules, "ModuleID", "ModuleName", Model.SelectedModules.Select(m => m.ModuleID)),
                new { multiple = "multiple", @class = "multiselectb" })
            </td>
            <td>
                <input type="button" id="btnAddModule" value=" + " />
            </td>
        </tr>

        @foreach (Module b in @Model.SelectedModules)
        {
            <tr>
                <td colspan="2">
                    @b.ModuleName
                </td>
            </tr>
        }
   </table>
}

当我在局部视图中单击保存按钮时,它应该更新自己的内容以及其他局部视图 SubSection2 应该被刷新。

在操作方法中,我返回新值,对于第二次部分视图更新,我创建了一个 ajax 提交函数,在其中执行 #secondpartialview.load 操作:

[HttpPost]
        public ActionResult EditSection1(Section1ViewModel viewModel)
        {
            Section1Data section1Data = new Section1Data(_UnitOfWork);
            // save changes
            section1Data.SaveSection1(viewModel);

            viewModel = section1Data.GetSection1ViewModel(viewModel.ProjectID);
            return PartialView("_Section1", viewModel);
        }

阿贾克斯提交:

$("#section1-form").submit(function () {

        $("#section1-saving").html("<img src='../../Images/ajax-loader.gif' />");

        $.ajax({
            url: this.action,
            type: this.method,
            data: $(this).serialize(),
            success: function (result) {
                $("#section1-saving").html("Saved!");
                $.ajaxSettings.cache = false;

                // Refresh the sub section 2 on the Section 2 tab
                $("#subSection2").load('../../Projects/subSection2/' + $("#ProjectID").val());
            },
            error: function (jqXHR, textStatus, errorThrown) {
                $("#section1-saving").html("Error: " + textStatus + " " + errorThrown);
            }
        });
        return false;
    });

问题是:调试器在操作方法中向我显示 selectedModules 的更新值,但不在 UI 上。

我错过了什么?

4

1 回答 1

2

当我在一个父视图中有多个部分视图时,我遇到了这种问题。你应该做的是,在父视图中调用 Section1 部分视图,如

 <div id="tab-section1">
            @{Html.RenderPartial("_Section1", Model.Section1);}
        </div>

现在在 _Section1 局部视图中调用您的 _Section2 局部视图

<div id="section2">
                @{Html.RenderPartial("_Section2", Model.Section2);}
            </div>

在局部视图中使用这种局部视图方法,您将能够从 UI 中获取值。这适用于父视图中的多个局部视图。我也喜欢称我的部分观点为

@Html.Partial("ViewName",Model.ModelName)
于 2013-11-12T11:54:53.337 回答