在 CreateView() 方法(在下面检查我的视图引擎)或在我的自定义操作过滤器(也在下面)中,我必须以某种方式检查我们请求的视图是否是 ViewUserControl。因为否则我会收到一个错误说
“当视图是 ViewUserControl 时,不能指定主名称。”
当我在 QueryString 中有“modal=true”并且视图请求是 ViewUsercontrol 时,因为您无法在 ViewUserControls 上设置母版页(显然)。
这是我现在的自定义视图引擎代码:
public class PendingViewEngine : VirtualPathProviderViewEngine
{
public PendingViewEngine()
{
// This is where we tell MVC where to look for our files.
/* {0} = view name or master page name
* {1} = controller name */
MasterLocationFormats = new[] {"~/Views/Shared/{0}.master", "~/Views/{0}.master"};
ViewLocationFormats = new[]
{
"~/Views/{1}/{0}.aspx", "~/Views/Shared/{0}.aspx", "~/Views/Shared/{0}.ascx",
"~/Views/{1}/{0}.ascx"
};
PartialViewLocationFormats = new[] {"~/Views/{1}/{0}.ascx", "~/Views/Shared/{0}.ascx"};
}
protected override IView CreatePartialView(ControllerContext controllerContext, string partialPath)
{
return new WebFormView(partialPath, "");
}
protected override IView CreateView(ControllerContext controllerContext, string viewPath, string masterPath)
{
return new WebFormView(viewPath, masterPath);
}
}
Run Code Online (Sandbox Code Playgroud)
我的动作过滤器:
public class CanReturnModalView : ActionFilterAttribute
{
public override void OnActionExecuted(ActionExecutedContext filterContext)
{
// setup the request, view and data
HttpRequestBase request = filterContext.RequestContext.HttpContext.Request;
bool modal = false;
if (request.QueryString["modal"] != null)
modal = bool.Parse(request.QueryString["modal"]);
if (filterContext.Result is ViewResult)
{
ViewResult view = (ViewResult) (filterContext.Result);
// replace the view Master page file with Modal Masterpage
if (modal)
view.MasterName = "AdministrationModal";
filterContext.Result = view;
}
else if (filterContext.Result is RedirectToRouteResult)
{
RedirectToRouteResult redirect = (RedirectToRouteResult) filterContext.Result;
// append modal route value to the redirect result if modal was requested
if (modal)
redirect.RouteValues.Add("modal", true);
filterContext.Result = redirect;
}
}
}
Run Code Online (Sandbox Code Playgroud)
上面的 ViewEngine 在这样的调用中失败:
<% Html.RenderAction("Display", "MyController", new { zoneslug = "some-zone-slug" });%>
Run Code Online (Sandbox Code Playgroud)
我在这里渲染的动作是这样的:
public ActionResult Display(string zoneslug)
{
WidgetZone zone;
if (!_repository.IsUniqueSlug(zoneslug))
zone = (WidgetZone) _repository.GetInstance(zoneslug);
else
{
// do something here
}
// WidgetZone used here is WidgetZone.ascx, so a partial
return View("WidgetZone", zone);
}
Run Code Online (Sandbox Code Playgroud)
我不能使用 RenderPartial,因为你不能像 RenderAction 那样将路由值发送到 RenderPartial。据我所知,没有办法像 RenderAction() 那样将 RouteValueDictionary 提供给 RenderPartial()。
您可以通过调用 PartialView 而不是视图来实现所描述的行为:
像现在一样创建视图:
<% Html.RenderAction("PartialIndex", new { test = "input" }); %>
Run Code Online (Sandbox Code Playgroud)
如您所见,它没有什么特别之处。
然后在您的控制器操作中,只需调用PartialView而不是 View:
public ActionResult PartialIndex(string test)
{
var viewResult = PartialView("PartialIndex", (object)test);
return viewResult;
}
Run Code Online (Sandbox Code Playgroud)
当模态参数传递到查询字符串时,还覆盖View方法以覆盖主名称。
public bool IsModal
{
get
{
var modalParameter = Request.QueryString["modal"];
if (string.IsNullOrEmpty(modalParameter))
return false;
bool modalValue;
var success = bool.TryParse(modalParameter, out modalValue);
return success && modalValue;
}
}
protected override ViewResult View(string viewName, string masterName, object model)
{
if (IsModal)
masterName = "Alternate";
return base.View(viewName, masterName, model);
}
Run Code Online (Sandbox Code Playgroud)
只有在渲染实际视图(而不是部分视图)时才会命中 View 方法覆盖,因此假设可以设置 masterName 是安全的。
| 归档时间: |
|
| 查看次数: |
3145 次 |
| 最近记录: |