繁体   English   中英

如何从单独的局部视图模态刷新提交时在主索引页面上的局部视图

[英]How can I refresh a partial view on the main index page on a submit from a separate partial view modal

我有一个主索引页面,该页面加载了包含dropdownfor列表的部分视图。 从ddl中选择一项会在单独的局部视图中填充控件以进行显示。 单击“编辑”会弹出一个带有“编辑器形式”的模型,该控件绑定到所选项目的模型属性。 单击模式的提交按钮时。 它把表单更新发布回数据库中……在这一点上,我想基本上刷新包含下拉列表的局部视图,以便它反映适当的更改。

我编写的代码执行了所有基本机制,没有问题,只是刷新了包含dropdownlistfor控件的局部视图。 我可以只对索引页面执行redirecttoaction并刷新整个页面,但我只希望刷新部分视图。 我无法弄清楚如何做到这一点,并且想知道是否有人提出建议。

索引页的div代码为:

@{
    ViewBag.Title = "Index";
    Layout = "~/Views/Shared/_Layout.cshtml";
}
<br />
<div class="partialContent" data-url="/Database/GetDatabases">
       @Html.Partial("_GetDatabases")
    </div>
<br />


<div class="modal fade" id="modalEditDBInfo" role="application" aria-labelledby="modalEditDBInfoLabel" aria-hidden="true">
    <div class="modal-dialog">
        <div class="modalEditDBInfoContent" style="background-color:white; border-radius:10px; box-shadow:10px;">
            @Html.Partial("_EditDatabaseInfo")
        </div>
    </div>
</div>

EditDatabase部分视图的代码

@model Hybridinator.WebUI.Models.DatabaseModel
<br />
<br />

<div class="modal-header">
    <button type="button" class="close" data-dismiss="modal"><span aria-hidden="true">&times;</span><span class="sr-only">Close</span></button>
    <h4 class="modal-title" id="editModelTitle">Edit Database Info</h4>
</div>
@if(Model != null)
{ 
    using (Html.BeginForm("EditDatabaseInfo", "Database", FormMethod.Post, new { @class = "modal-form" }))
    {
        <div class="modal-body">
            @Html.HiddenFor(m => m.database_pk, new { htmlAttributes = new { @class = "form-control" } })
            <div class="form-group">
                <div id="databaselabel">@Html.LabelFor(m => m.database_name, "Database")</div>
                <div id="databaseedit">@Html.EditorFor(m => m.database_name, new { htmlAttributes = new { @class = "form-control" } })</div>
            </div>
            <div class="form-group">
                <div id="databaseserverlabel">@Html.LabelFor(m => m.database_server, "Database Server")</div>
                <div id="databaseserveredit">@Html.EditorFor(m => m.database_server, new { htmlAttributes = new { @class = "form-control" } })</div>
            </div>

            </div>

            <div class="form-group">
                <div id="editsqltypelabel">@Html.LabelFor(m => m.sql_type_pk, "Sql Type")</div>
                <div id="editsqltypeddl">@Html.DropDownListFor(m => m.sql_type_pk, Model.sqlTypes)</div>
            </div>

            </div>
            <div class="modal-footer">
                <button type="button" class="btn btn-default" data-dismiss="modal">Cancel</button>
                <button class="btn btn-inverse btn-primary" type="submit">Save</button>
            </div>
    }       
}

GetDatabases部分视图的代码

@model Hybridinator.WebUI.Models.DatabaseListModel
@if(Model != null)
{    
    <div id="databasedropdown" class="container-fluid">
        @Html.Label("Databases: ")@Html.DropDownListFor(m => m.database_pk, Model.databases, "Select one...", new { @id = "database_pk", onchange = "changeDatabase()" })  
    </div>
}

GetDatabases的控制器代码

public ActionResult GetDatabases()
        {
            DatabaseListModel databaseListModel = new DatabaseListModel
            {
                databases = databaseService.GetUndeletedDatabaseList().
                    Select(d => new SelectListItem
                    {
                        Value = d.database_pk.ToString(),
                        Text = d.database_name
                    }).ToList()
            };
            return PartialView("_GetDatabases",databaseListModel);
        }

最后为EditDatabase模式的Get和Post代码

[HttpGet]
public ActionResult EditDatabaseInfo(int database_pk)
{
    DatabaseModel databaseModel = FillDatabaseModelByDatabasePK(database_pk);
    return PartialView("_EditDatabaseInfo", databaseModel);
}
[HttpPost]
public ActionResult EditDatabaseInfo(DatabaseModel databaseModel)
{
    string[] result = databaseService.Update(new Database
    {
        database_pk = databaseModel.database_pk,
        database_name = databaseModel.database_name,
        database_password = databaseModel.database_password,
        database_username = databaseModel.database_username,
        database_server = databaseModel.database_server,
        hist_database_name = databaseModel.hist_database_name,
        hist_database_server = databaseModel.hist_database_server,
        hist_database_password = databaseModel.hist_database_password,
        hist_database_username = databaseModel.hist_database_username,
        sqlType = new SQLType { sql_type_pk = databaseModel.sql_type_pk }
    });
    return RedirectToAction("GetDatabases");
}

正如我说过的,在Post EditDatabase控制器方法中返回的RedirectToAction(“ Index)可以正常使用..但是我真的不想刷新整个页面。我认为在该方法的返回中我可以做些不同的事情只是重新加载GetDatabases部分,但我无法弄清楚,任何帮助将不胜感激。

以上评论的卡尔提供了解决方案。 Buts因为他刚刚发表评论,Ill在这里发表了代码修改,所以如果有人正在寻找类似的问题,他们可以看到代码。

按照卡尔的建议,我使用Ajax.BeginForm而不是HTML.BeginForm和IM通过onsuccess处理程序更新部分视图控制器。

我在EditDatabase部分中替换了这一行

     using (Html.BeginForm("EditDatabaseInfo", "Database", FormMethod.Post, new { @class = "modal-form" }))

有了这个

using (Ajax.BeginForm("EditDatabaseInfo", "Database", new AjaxOptions{
            InsertionMode = InsertionMode.Replace,
            HttpMethod = "POST",
            OnSuccess = "editDatabaseSuccess"        
        }, new { @id = "editDatabaseForm" }))

然后在脚本中,我为editDatabaseSucess创建了一个函数

<script type="text/javascript">
    function editDatabaseSuccess(data)
    {
        //alert(data);
        $('#modalEditDBInfo').modal('hide');
        loadDatabases();
    }
</script>

alert(data;注释掉的行仅用于测试,以确保该函数被调用。loadDatabases();该行调用我在页面加载时使用的函数以加载部分视图。

<script type="text/javascript">
    function loadDatabases()
    {
        $(".partialContent").each(function (index, item) {
            var url = $(item).data("url");
            if (url && url.length > 0) {
                $(item).load(url)
            }
        });
    }
</script>

现在可以完美运行。 非常感谢卡尔的回答。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM