[转载]ASP.NET MVC 多套皮肤解决方案 - Daniel Chow - 博客园

[转载]ASP.NET MVC 多套皮肤解决方案 – Daniel Chow – 博客园.

原理自己写了一个ThemeController继承于Controller,先看我的文件结构:

ThemeController的具体实现:

 

复制代码
  public class ThemeController : Controller
{
private static string[] sPathTemplate = new string[]{
/Themes/{0}/{1}/{2}.aspx,
/Themes/{0}/Shared/{1}.Master};

        private static ThemeController m_ThemeController = new ThemeController();

public static ViewResult View(string sTheme, string sController, string sView, string sMaster, object oModel)
{
string sViewPath = string.Format(sPathTemplate[0], sTheme, sController, sView);
string sMasterPath = string.Format(sPathTemplate[1], sTheme, sMaster);

return m_ThemeController.View(sViewPath, sMasterPath, oModel);
}

public static ViewResult View(string sTheme, string sController, string sView, object oModel)
{
return View(sTheme, sController, sView,Site , oModel);
}

public static ViewResult View(string sTheme, string sController, string sView)
{
string sViewPath = string.Format(sPathTemplate[0], sTheme, sController, sView);
string sMasterPath = string.Format(sPathTemplate[1], sTheme, Site);

return m_ThemeController.View(sViewPath, sMasterPath);
}

//protected override ViewResult View(string viewName, string masterName, object model)
//{
//    if (viewName == null && model != null)
//        viewName = model.GetType().Name.ToLower().Replace(“model”, “view”);

//    return base.View(viewName, masterName, model);
//}
    }

复制代码

 

调用方法:

复制代码
[HandleError]
public class HomeController : ThemeController
{
public ActionResult Index()
{
string m_sTheme = default; //默认的皮肤

if (Request.QueryString[Theme!= null)
{
m_sTheme 
= Request.QueryString[Theme];
}

ViewData[Message= Welcome to ASP.NET MVC!;

return View(m_sTheme, HomeIndex);
}

public ActionResult About()
{
return View();
}
}

复制代码

 

显示效果:

 

自己觉得这是一个比较粗浅的解决方案,算是抛砖引玉吧,敬请多多拍砖!

 

附上源码!

 

更好的解决方案:重写视图引擎 附上源代码

赞(0) 打赏
分享到: 更多 (0)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏