Імовірно, основним випадком використання для цього є отримання базової моделі для перегляду для всіх (або більшості) дій контролера.
Враховуючи це, я використав комбінацію кількох цих відповідей, першочергову скарбничку на відповідь Коліна Бекона.
Правильно, що це все-таки логіка контролера, тому що ми заповнюємо модель перегляду для повернення до перегляду. Таким чином, правильне місце для цього - у контролері.
Ми хочемо, щоб це сталося на всіх контролерах, оскільки ми використовуємо це для сторінки макета. Я використовую його для часткових переглядів, які відображаються на сторінці макета.
Ми все ще хочемо додаткової переваги сильно набраного ViewModel
Таким чином, я створив BaseViewModel і BaseController. Усі контролери ViewModels успадкують від BaseViewModel та BaseController відповідно.
Код:
BaseController
public class BaseController : Controller
{
protected override void OnActionExecuted(ActionExecutedContext filterContext)
{
base.OnActionExecuted(filterContext);
var model = filterContext.Controller.ViewData.Model as BaseViewModel;
model.AwesomeModelProperty = "Awesome Property Value";
model.FooterModel = this.getFooterModel();
}
protected FooterModel getFooterModel()
{
FooterModel model = new FooterModel();
model.FooterModelProperty = "OMG Becky!!! Another Awesome Property!";
}
}
Зверніть увагу на використання OnActionExecuted , прийнятого з цієї публікації SO
HomeController
public class HomeController : BaseController
{
public ActionResult Index(string id)
{
HomeIndexModel model = new HomeIndexModel();
// populate HomeIndexModel ...
return View(model);
}
}
BaseViewModel
public class BaseViewModel
{
public string AwesomeModelProperty { get; set; }
public FooterModel FooterModel { get; set; }
}
HomeViewModel
public class HomeIndexModel : BaseViewModel
{
public string FirstName { get; set; }
// other awesome properties
}
FooterModel
public class FooterModel
{
public string FooterModelProperty { get; set; }
}
Layout.cshtml
@model WebSite.Models.BaseViewModel
<!DOCTYPE html>
<html>
<head>
< ... meta tags and styles and whatnot ... >
</head>
<body>
<header>
@{ Html.RenderPartial("_Nav", Model.FooterModel.FooterModelProperty);}
</header>
<main>
<div class="container">
@RenderBody()
</div>
@{ Html.RenderPartial("_AnotherPartial", Model); }
@{ Html.RenderPartial("_Contact"); }
</main>
<footer>
@{ Html.RenderPartial("_Footer", Model.FooterModel); }
</footer>
< ... render scripts ... >
@RenderSection("scripts", required: false)
</body>
</html>
_Nav.cshtml
@model string
<nav>
<ul>
<li>
<a href="@Model" target="_blank">Mind Blown!</a>
</li>
</ul>
</nav>
Сподіваємось, це допомагає.