También puede hacer que un PartialViewResult en una cadena, y luego pasar a través de esta cadena JSON a la vista, lo que hace que en tu página usando jQuery.
Puedes verlo en esta publicación: http://www.atlanticbt.com/blog/asp-net-mvc-using-ajax-json-and-partialviews/.
He creado una extensión para que sea más fácil:
public static class MvcHelpers
{
public static string RenderPartialView(this Controller controller, string viewName, object model)
{
if (string.IsNullOrEmpty(viewName))
viewName = controller.ControllerContext.RouteData.GetRequiredString("action");
controller.ViewData.Model = model;
using (var sw = new StringWriter())
{
ViewEngineResult viewResult = ViewEngines.Engines.FindPartialView(controller.ControllerContext, viewName);
var viewContext = new ViewContext(controller.ControllerContext, viewResult.View, controller.ViewData, controller.TempData, sw);
viewResult.View.Render(viewContext, sw);
return sw.GetStringBuilder().ToString();
}
}
}
En mi controlador de la llamo de la siguiente manera:
const string msg = "Item succesfully updated!";
return new JsonResult
{
Data = new
{
success = true,
message = msg,
view = this.RenderPartialView("ProductItemForm", model)
},
JsonRequestBehavior = JsonRequestBehavior.AllowGet
};
Donde "este" es el controlador en el caso " ProductItemForm" es mi opinión y "modelo" es mi objeto productItem :)
esperanza esto ayuda;)
Me gusta este enfoque. Agregué la clase RenderPartialView a mi controlador base, así que lo hago a menudo. – jsalwen