Mysql
 sql >> Base de données >  >> RDS >> Mysql

ASP.NET MVC 4, plusieurs modèles dans une seule vue ?

Si vous n'avez pas encore de modèle de vue pour représenter cela, créez-en un :

public class MyViewModel
{
    public Engineer Engineer { get; set; }
    public List<Element> Elements { get; set; }
}

Remplir un ensemble de modèles de vue dans le contrôleur

public ActionResult MyAction()
{
    var viewModels = 
        (from e in db.Engineers
         select new MyViewModel
         {
             Engineer = e,
             Elements = e.Elements,
         })
        .ToList();
    return View(viewModels);
}

Et dans votre vue, précisez simplement que vous utilisez une collection de modèles de vue :

@model List<MyViewModel>
@foreach(var vm in Model)
{
    <h1>Projects for engineer: @vm.Engineer.Name</ha>
    <ul>
    @foreach(var ele in vm.Elements)
    {
        <li>@ele.Name</li>
    }
    </ul>
}