他のモデルには、いくつかのprtialviewを使用する必要があります。メインモデルのメインビューがあります。そのビューの中に、モデルと検証を含むいくつかの部分ビューを含めることができます。
- - - - - - - - - - - - - - - - - - - 編集:
他の人が言ったように、ビューモデルを使用してモデルを互いに組み合わせる方が良いです。しかし、あなたが望むように、私は私のGithubアカウントであなたのためにサンプルプロジェクトを作成しました:
https://github.com/bahman616/ASPNET_MVC_multiple_models_in_a_view_with_partialview.git
そのプロジェクトの簡略化されたコードは次のとおりです。
2つのモデルがあります:
public partial class Person
{
public int ID { get; set; }
[Required]
public string Name { get; set; }
}
public partial class Company
{
public int Id { get; set; }
[Required]
public string Name { get; set; }
}
両方が1つのビューにビューを作成するようにしたいので、これは親ビューです。
@model ASP_NET_MVC_Multiple_Models_In_A_View.Models.Person
@{
ViewBag.Title = "Create";
}
<h2>Create</h2>
@using (Html.BeginForm("Create","Person")) {
@Html.ValidationSummary(true)
<fieldset>
<legend>Person</legend>
<div class="editor-label">
@Html.LabelFor(model => model.Name)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Name)
@Html.ValidationMessageFor(model => model.Name)
</div>
<p>
<input type="submit" value="Create" />
</p>
</fieldset>
}
<div>
@Html.ActionLink("Back to List", "Index")
</div>
@{Html.RenderAction("_CompanyCreate", "Company");}
@section Scripts {
@Scripts.Render("~/bundles/jqueryval")
}
そして、これは部分的なビューです:
@model ASP_NET_MVC_Multiple_Models_In_A_View.Models.Company
<script src="~/Scripts/jquery-1.7.1.min.js"></script>
<script src="~/Scripts/jquery.validate.min.js"></script>
<script src="~/Scripts/jquery.validate.unobtrusive.min.js"></script>
@using (Html.BeginForm("_CompanyCreate","Company")) {
@Html.ValidationSummary(true)
<fieldset>
<legend>Company</legend>
<div class="editor-label">
@Html.LabelFor(model => model.Name)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Name)
@Html.ValidationMessageFor(model => model.Name)
</div>
<p>
<input type="submit" value="Create" />
</p>
</fieldset>
}
<div>
@Html.ActionLink("Back to List", "Index")
</div>