部分视图表单通过ajax提交以返回部分视图

时间:2017-09-01 04:13:33

标签: javascript jquery ajax asp.net-mvc asp.net-mvc-4

我陷入两难境地。请发送帮助!

我正在构建一个MVC 4 Web应用程序,并且在加载另一个局部视图的表单时无法获得部分视图加载到页面的某个部分。以下是我到目前为止所做的事情:

在基页( ReviewPage )上,我有一个部分在加载页面时加载部分视图。像这样:

body

以下是控制器中_CompanyNotes操作最初加载的局部视图( _NoNotes ):

@model AppV4.Models.NewCompanyRequest

@{
    ViewBag.Title = "ReviewNewRequest";
}

<h2>New Sign Up Review</h2>


<div class="container">
    <div class="row">
        <div class="col-lg-8 col-md-8">
            <div id="company_notes">
                 @Html.Action("_CompanyNotes")
            </div>
        </div>
    </div>
</div>

在此_NoNotes局部视图中单击“添加注释”按钮时,控制器中的_CompanyNotesEditGet操作将返回部分视图( _NotesForm ),该视图将替换#company_notes div中页面上的_NoNotes。这可以正常工作。这是_NotesForm局部视图:

@model AppV4.Models.ViewModels.NotesOnCompanyViewModel

<h4>Notes on Company</h4>

<div class="row text-center col-sm-6 col-sm-offset-6">
    <div class="text-center">
        <div class="primary-action-bttn-border">
            <div class="primary-action-bttn-bkg">
                @Ajax.ActionLink("Add Note", "_CompanyNotesEditGet", Model, new AjaxOptions { UpdateTargetId = "company_notes", InsertionMode = InsertionMode.Replace, HttpMethod = "GET" }, new { @class = "btn btn-default primary-action-bttn" })
            </div>
        </div>
    </div>
</div>

<div class="row text-center padding-25-top">
    <p>There are no notes for this company.  Do you want to add some?</p>
</div>
 @Html.HiddenFor(item => Model.RequestId)

我想要发生的事情:当文本输入到Notes字段并按下提交时,我希望将数据传递给控制器​​,以便将其保存到数据库并有一个新的局部视图替换页面上的_NotesForm部分。

当前发生的事情:当文本输入到Notes字段并按下提交时,控制器会接收数据并完成工作。但是,它不是替换刚刚提交的表单的部分视图,而是替换整个页面。从字面上看,整个页面将替换为此局部视图的内容。

我尝试使用我在这里和其他地方找到的各种表单提交技术,但似乎没有任何工作方式符合我的要求。

以下是应该返回部分视图的控制器操作 _CompanyNotes

@model AppV4.Models.ViewModels.NotesOnCompanyViewModel

<form data-gp-ajax="true" action="@Url.Action("_CompanyNotesEditPost", "NewSignUpRequestReview")" method="post" data-gp-target="#company-notes">
    <div class="form-horizontal">
        <h4>Notes On Company</h4>
        <hr />
        @Html.ValidationSummary(true, "", new { @class = "text-danger" })
        @Html.HiddenFor(model => model.NotesId)
        @Html.HiddenFor(model => model.CompanyId)

        <div class="form-group">

            @Html.LabelFor(model => model.Notes, htmlAttributes: new { @class = "control-label col-md-2 text-left" })
            <div class="col-md-12">
                @Html.EditorFor(model => model.Notes, new { htmlAttributes = new { @class = "form-control" } })
                @Html.ValidationMessageFor(model => model.Notes, "", new { @class = "text-danger" })
            </div>
        </div>

        <div class="form-group">
            <div class="col-md-offset-2 col-md-10">
                <input type="submit" value="Save" class="btn btn-default" />
            </div>
        </div>
    </div>
</form>

以下是我为捕获提交事件而编写的JavaScript,运行相应的控制器操作,然后将部分视图放回ReviewPage:

[HttpPost]
public ActionResult _CompanyNotesEditPost(NotesOnCompanyViewModel notesOnCompanyViewModel)
{
    //code that reviews the notes and places it into the db//

    return PartialView("~/Views/NotesOnCompany/_CompanyNotes.cshtml", notesOnCompanyViewModel);
}

我的理论是,我没有以某种方式使用我的js代码捕获提交事件,而是提交操作直接进入我的控制器,这导致了问题。但是,我已确保将我的js脚本添加到通过_Layout视图添加到每个视图底部的脚本包中。所以我真的在这里大吃一惊。有谁想?

1 个答案:

答案 0 :(得分:0)

我尝试了事件传播方法,但仍然得到了相同的结果。提交将直接转到控制器并使用部分视图刷新整个页面,而不是js捕获事件。

我将id="edit-company-notes"添加到局部视图_NotesForm上的表单标记。

写下我为事件传播写的以下js:

$('div#company_notes').on('.submit', '#edit-company-notes', function () {

        var $form = $(this);

        $.ajax({
            url: $form.attr("action"),
            type: $form.attr("method"),
            data: $form.serialize(),
            success: function (viewHTML) {
                $("#company_notes").show();
                $("#company_notes").html(viewHTML);
            }
        });

        return false;
    });

使用'.submit'代替'submit'完全搞错了!那个时期导致整个事情被忽略了!

以下是事件处理程序的正确js:

$('div#company_notes').on('submit', '#edit-company-notes', function () {

    var $form = $(this);

    $.ajax({
        url: $form.attr("action"),
        type: $form.attr("method"),
        data: $form.serialize(),
        success: function (viewHTML) {
            $("#company_notes").show();
            $("#company_notes").html(viewHTML);
            }
    });

    return false;
});

我希望这能帮助别人像昨晚一样把头撞在墙上!