Прошло некоторое время, но я нашел отличное решение. Поскольку решение Keith работает для многих людей, но в определенных ситуациях оно не является лучшим, потому что иногда вы хотите, чтобы ваше приложение проходило процесс контроллера для рендеринга вида и Решение Кейта просто отображает вид с заданной моделью Я представляю здесь новое решение, которое будет запускать обычный процесс.
Общие шаги:
- Создать класс утилит
- Создание фиктивного контроллера с фиктивным видом
- В вашем
aspx
или master page
вызовите служебный метод для частичного рендеринга, передавая контроллер, представление и, если вам нужно, модель для рендеринга (как объект),
Давайте проверим это внимательно в этом примере
1) Создайте класс с именем MVCUtility
и создайте следующие методы:
//Render a partial view, like Keith's solution
private static void RenderPartial(string partialViewName, object model)
{
HttpContextBase httpContextBase = new HttpContextWrapper(HttpContext.Current);
RouteData routeData = new RouteData();
routeData.Values.Add("controller", "Dummy");
ControllerContext controllerContext = new ControllerContext(new RequestContext(httpContextBase, routeData), new DummyController());
IView view = FindPartialView(controllerContext, partialViewName);
ViewContext viewContext = new ViewContext(controllerContext, view, new ViewDataDictionary { Model = model }, new TempDataDictionary(), httpContextBase.Response.Output);
view.Render(viewContext, httpContextBase.Response.Output);
}
//Find the view, if not throw an exception
private static IView FindPartialView(ControllerContext controllerContext, string partialViewName)
{
ViewEngineResult result = ViewEngines.Engines.FindPartialView(controllerContext, partialViewName);
if (result.View != null)
{
return result.View;
}
StringBuilder locationsText = new StringBuilder();
foreach (string location in result.SearchedLocations)
{
locationsText.AppendLine();
locationsText.Append(location);
}
throw new InvalidOperationException(String.Format("Partial view {0} not found. Locations Searched: {1}", partialViewName, locationsText));
}
//Here the method that will be called from MasterPage or Aspx
public static void RenderAction(string controllerName, string actionName, object routeValues)
{
RenderPartial("PartialRender", new RenderActionViewModel() { ControllerName = controllerName, ActionName = actionName, RouteValues = routeValues });
}
Создайте класс для передачи параметров, я назову здесь RendeActionViewModel (вы можете создать в том же файле класса MvcUtility)
public class RenderActionViewModel
{
public string ControllerName { get; set; }
public string ActionName { get; set; }
public object RouteValues { get; set; }
}
2) Теперь создайте контроллер с именем DummyController
//Here the Dummy controller with Dummy view
public class DummyController : Controller
{
public ActionResult PartialRender()
{
return PartialView();
}
}
Создайте фиктивный вид с именем PartialRender.cshtml
(вид бритвы) для DummyController
со следующим содержимым, обратите внимание, что он выполнит другое действие рендеринга, используя Html helper
@model Portal.MVC.MvcUtility.RenderActionViewModel
@{Html.RenderAction(Model.ActionName, Model.ControllerName, Model.RouteValues);}
3) Теперь просто поместите это в файл MasterPage
или aspx
, чтобы частично отобразить нужный вам вид. Обратите внимание, что это отличный ответ, если у вас есть несколько видов бритвы, которые вы хотите смешать со своими MasterPage
или aspx
страницами. (Предполагается, что у нас есть PartialView, называемый Login для контроллера. Home
<% MyApplication.MvcUtility.RenderAction("Home", "Login", new { }); %>
или если у вас есть модель для перехода в действие
<% MyApplication.MvcUtility.RenderAction("Home", "Login", new { Name="Daniel", Age = 30 }); %>
Это отличное решение, не использует ajax-вызов , что не вызовет отложенный рендеринг для вложенных представлений, не делает новый WebRequest так что не принесет вам новый сеанс , а обработает метод получения ActionResult для требуемого представления, работает без прохождения любой модели
Благодаря Использование MVC RenderAction в веб-форме