asp.net-mvc
1つのビューで複数のモデルを使用する
サーチ…
前書き
このトピックの主な焦点は、MVCのビューレイヤーで複数のモデルクラスを使用することです
動的ExpandoObjectを使用したビューで複数のモデルを使用する
ExpandoObject( System.Dynamic
名前空間)は.Net Framework 4.0
に追加されたクラスです。このクラスを使用すると、実行時にプロパティをオブジェクトに動的に追加および削除できます。 Expandoオブジェクトを使用することにより、動的に作成されたExpandoオブジェクトにモデルクラスを追加できます。以下の例は、この動的オブジェクトをどのように使用できるかを説明しています。
教師と学生モデル:
public class Teacher
{
public int TeacherId { get; set; }
public string Name { get; set; }
}
public class Student
{
public int StudentId { get; set; }
public string Name { get; set; }
}
教師と生徒リスト方法:
public List<Teacher> GetTeachers()
{
List<Teacher> teachers = new List<Teacher>();
teachers.Add(new Teacher { TeacherId = 1, Name = "Teacher1" });
teachers.Add(new Teacher { TeacherId = 2, Name = "Teacher2" });
teachers.Add(new Teacher { TeacherId = 3, Name = "Teacher3" });
return teachers;
}
public List<Student> GetStudents()
{
List<Student> students = new List<Student>();
students.Add(new Student { StudentId = 1, Name = "Student1"});
students.Add(new Student { StudentId = 2, Name = "Student2"});
students.Add(new Student { StudentId = 3, Name = "Student3"});
return students;
}
コントローラ(動的モデルを使用):
public class HomeController : Controller
{
public ActionResult Index()
{
ViewBag.Message = "Hello World";
dynamic mymodel = new ExpandoObject();
mymodel.Teachers = GetTeachers();
mymodel.Students = GetStudents();
return View(mymodel);
}
}
表示:
@using ProjectName ; // Project Name
@model dynamic
@{
ViewBag.Title = "Home Page";
}
<h2>@ViewBag.Message</h2>
<h2>Teacher List</h2>
<table>
<tr>
<th>Id</th>
<th>Name</th>
</tr>
@foreach (Teacher teacher in Model.Teachers)
{
<tr>
<td>@teacher.TeacherId</td>
<td>@teacher.Name</td>
</tr>
}
</table>
<h2>Student List</h2>
<table>
<tr>
<th>Id</th>
<th>Name</th>
</tr>
@foreach (Student student in Model.Students)
{
<tr>
<td>@student.StudentId</td>
<td>@student.Name</td>
</tr>
}
</table>
Modified text is an extract of the original Stack Overflow Documentation
ライセンスを受けた CC BY-SA 3.0
所属していない Stack Overflow