5

我在同一个控制器类中有某些看起来几乎相同的代码,例如设置视图包以填充所有下拉列表,相同的代码适用于我的 Post 并获取 Create 和 Edit 操作方法。因此,我在控制器类的末尾创建了一个私有方法,如下所示:-

private void populateViewBags()
{
    string controllerName = RouteData.Values["controller"].ToString();
    ViewBag.PossibleDataCenters = repository.AllDataCenter().OrderBy(a => a.Name).ToList();
    ViewBag.PossibleZones = repository.AllZone().OrderBy(a => a.Name).ToList();
    List<string> s = new List<string>();
    s.Add(controllerName.ToLower());
    ViewBag.Products = repository.GetProducts(s).OrderBy(a => a.COMPONENTNAME).ToList();
    ViewBag.Sites = repository.GetSDOrg().OrderBy(a => a.NAME).ToList();
    ViewBag.Customers = repository.FindAccountDefinition(null).ToList();
}

我在我的操作方法中调用这个方法。那么它是重用代码的正确方法吗?谢谢

4

1 回答 1

4

有两种标准方法可以做到这一点。

第一种方法- 覆盖OnActionExecuting和/或OnActionExecuted控制器类的方法:

public class HomeController: Controller
{
    protected override void OnActionExecuting(ActionExecutingContext filterContext)
    {
        string controllerName = RouteData.Values["controller"].ToString();
        ViewBag.ControllerName = controllerName;
    }

    protected override void OnActionExecuted(ActionExecutedContext filterContext)
    {
        string controllerName = RouteData.Values["controller"].ToString();
        ViewBag.ControllerName = controllerName;
    }
}

您还可以制作实现这些方法的抽象基础控制器,然后从抽象控制器继承具体控制器,这样您就不会在每个控制器中重复代码代码。

第二种方法- 制作自定义ActionFilter属性并装饰需要执行其他操作的每个控制器。

public class MyActionFilterAttribute: ActionFilterAttribute
{
    public override void OnActionExecuting(ActionExecutingContext filterContext)
    {
        string controllerName = filterContext.RouteData.Values["controller"].ToString();
        filterContext.Controller.ViewBag.ControllerName = controllerName;
    }

    public override void OnActionExecuted(ActionExecutedContext filterContext)
    {
        string controllerName = filterContext.RouteData.Values["controller"].ToString();
        filterContext.Controller.ViewBag.ControllerName = controllerName;
    }
}

然后只需装饰控制器,例如:

[MyActionFilter]
public class HomeController: Controller
{
    // ....
}

更新:过滤器方法的额外灵活性,如果您需要基于每个操作进行过滤,而不是控制器中的所有操作,它也是可能的:

public class HomeController: Controller
{
    [MyActionFilter]
    public ActionResult MyAction()
    {
        //...
    }
}
于 2013-08-10T18:19:20.587 回答