34

現在、強く型付けされた 2 つのビューで構成されるフォームを投稿しようとしています。この質問は似ていますが、答えがありません:

MVC 3 Razor フォームの投稿と複数の厳密に型指定された部分ビューがバインドされていない

フォームを送信すると、コントローラーに送信されたモデルは常に null になります。これを機能させるために数時間を費やしました。これは単純なはずです。ここで何か不足していますか?コントローラーに投稿して新しいページをレンダリングできるようにするだけで、ajax を実行する必要はありません。

ありがとう

これが私のビューコードです:

<div>
    @using (Html.BeginForm("TransactionReport", "Reports", FormMethod.Post, new {id="report_request"}))
    {
        ViewContext.FormContext.ValidationSummaryId = "valSumId";
        @Html.ValidationSummary(false, "Please fix these error(s) and try again.", new Dictionary<string, object> { { "id", "valSumId" } });
        @Html.Partial("_ReportOptions", Model.ReportOptions);
        @Html.Partial("_TransactionSearchFields", new ViewDataDictionary(viewData) { Model = Model.SearchCriteria });
    }

コントローラーのコードは次のとおりです。

[AcceptVerbs(HttpVerbs.Post)]
public ActionResult TransactionReport(TransactionReportRequest reportRequest)
{
    var reportInfo = new List<TransactionReportItem>();

    if (ModelState.IsValid)
    {
        var reportData = _reportDataService.GetReportData(Search.MapToDomainSearchCriteria(reportRequest.SearchCriteria));
        if (reportData!=null)
        {
            reportInfo = reportData.ToList();
        }
        return View(reportInfo);
    }
    return View(reportInfo);
}

部分ビュー自体は、入札とモデルの表示だけを行っているため、ほとんど関係ありません。

4

5 に答える 5

56

パーシャルはここに行く方法ではありません。EditorTemplates を探しています。これらは目的に合わせて作成されています。この場合、プロパティはモデル (送信するモデル) に適切にバインドされます。

EditorForメイン ビューには次の形式があります (の代わりに使用するだけでよいことに注意してくださいPartial。この場合、おそらくその viewData パラメータを ViewBag などに配置する必要があります)。

@using (Html.BeginForm("TransactionReport", "Reports", FormMethod.Post, new {id="report_request"}))
{
    ViewContext.FormContext.ValidationSummaryId = "valSumId";
    @Html.ValidationSummary(false, "Please fix these error(s) and try again.", new Dictionary<string, object> { { "id", "valSumId" } });
    @Html.EditorFor(model => model.ReportOptions);
    @Html.EditorFor(model = Model.SearchCriteria });
}

これで、パーシャルをフォルダーにドラッグし~/Shared/EditorTemplates/、エディター テンプレートのモデル名と一致するように名前を変更するだけで済みます。

~/Shared/EditorTemplates/フォルダーで、新しい「ビュー」、たとえば「SearchCriteria.cshtml」を作成します。内部では、エディタ テンプレートを作成するクラスのタイプを「モデル」として入力します。例 (例のクラスにはプロパティNameとがありますOtherCriteria):

@model MyNamespace.SearchCriteria
<ul>
    <!-- Note that I also use EditorFor for the properties; this way you can "nest" editor templates or create custom editor templates for system types (like DateTime or String or ...). -->
    <li>@Html.LabelFor(m => m.Name): @Html.EditorFor(m => m.Name)</li>
    <li>@Html.LabelFor(m => OtherCriteria): @Html.EditorFor(m => m.OtherCriteria</li>
</ul>

それらについての良い読み物:

于 2012-05-15T21:02:35.723 に答える
10

@Styxxy と @Tony に同意します。Editor Templates の方が優れたソリューションです。ただし、問題は、サブモデルを部分ビューにフィードしていることです。したがって、部分ビューがレンダリングされるとき、それがより大きなモデルの一部であることを認識せず、正しい名前属性を生成しません。

Editor Templates ではなく Partials を使用することを主張する場合は、モデルのみをパーシャルに渡し、各パーシャルに Model.Whatever.Foo を実行させることをお勧めします。これにより、バインディング用の正しい名前属性が生成されます。

于 2012-05-15T21:10:56.457 に答える
4

Partials http://coding-in.net/asp-net-mvc-3-how-to-use-editortemplates/の代わりに EditorTemplates を使用してみてください。

于 2012-05-15T21:06:07.337 に答える
2
@Html.Partial("_ReportOptions", Model.Contact, new ViewDataDictionary()
           {
               TemplateInfo = new TemplateInfo()
                   {
                       HtmlFieldPrefix = "Contact"
                   }
           })

)


@Html.Partial("_TransactionSearchFields", Model.SearchCriteria, new  
 ViewDataDictionary()
           {
               TemplateInfo = new TemplateInfo()
                   {
                       HtmlFieldPrefix = "SearchCriteria"
                   }
           })
于 2015-09-15T05:39:10.973 に答える