Принятый ответ @Chev выше хорош, но я хотел отобразить результат определенного действия , а не только конкретного представления .
ТакжеМне нужно было иметь возможность передавать параметры этому действию, а не полагаться на внедрение модели.
Поэтому я придумал свой собственный метод, который я поместил в базовый класс своих контроллеров (делая его доступным дляих все):
protected string RenderViewResultAsString(ViewResult viewResult)
{
using (var stringWriter = new StringWriter())
{
this.RenderViewResult(viewResult, stringWriter);
return stringWriter.ToString();
}
}
protected void RenderViewResult(ViewResult viewResult, TextWriter textWriter)
{
var viewEngineResult = this.ViewEngineCollection.FindView(
this.ControllerContext,
viewResult.ViewName,
viewResult.MasterName);
var view = viewEngineResult.View;
try
{
var viewContext = new ViewContext(
this.ControllerContext,
view,
this.ViewData,
this.TempData,
textWriter);
view.Render(viewContext, textWriter);
}
finally
{
viewEngineResult.ViewEngine.ReleaseView(this.ControllerContext, view);
}
}
Предположим, у меня есть действие с именем Foo
, которое принимает объект модели и некоторые другие параметры, которые вместе влияют на то, какой вид будет использоваться:
public ViewResult Foo(MyModel model, int bar)
{
if (bar == 1)
return this.View("Bar1");
else
return this.View("Bar2", model);
}
Теперь, если я хочу получить результат вызова действия Foo
, я могу просто получить ViewResult
, вызвав метод Foo
, а затем вызвать RenderViewResultAsString
, чтобы получить текст HTML:
var viewResult = this.Foo(model, bar);
var html = this.RenderViewResultAsString(viewResult);