Vous pouvez également rendre une PartialViewResult à une chaîne, et ensuite passer cette chaîne via JSON à votre point de vue, ce qui rend en votre page en utilisant jQuery.
Vous pouvez le voir dans cet article: http://www.atlanticbt.com/blog/asp-net-mvc-using-ajax-json-and-partialviews/.
J'ai créé une extension pour le rendre plus facile:
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();
}
}
}
Dans mon contrôleur je l'appelle comme suit:
const string msg = "Item succesfully updated!";
return new JsonResult
{
Data = new
{
success = true,
message = msg,
view = this.RenderPartialView("ProductItemForm", model)
},
JsonRequestBehavior = JsonRequestBehavior.AllowGet
};
Où « ce » est le contrôleur dans le cas, " ProductItemForm » est mon avis et "modèle" est mon objet productItem :)
Hope this helps;)
J'aime cette approche. J'ai ajouté le RenderPartialView à ma classe de contrôleur de base, donc je le fais souvent. – jsalwen