自定义View视图
2015-06-02 23:13
387 查看
自定义View视图文件查找逻辑
之前MVC5和之前的版本中,我们要想对View文件的路径进行控制的话,则必须要对IViewEngine接口的
FindPartialView或
FindView方法进行重写,所有的视图引擎都继承于该
IViewEngine接口,比如默认的
RazorViewEngine。但新版本MVC6中,对视图文件的路径方式却不太一样了,目前有两种方式,一种是通过
RazorViewEngine,另外一种是通过新特性
IViewLocationExpander接口。
通过RazorViewEngine来控制View路径
在新版的RazorViewEngine中,该类提供了两个虚属性(
AreaViewLocationFormats和
ViewLocationFormats),可以用于重写控制,而不必再对
FindPartialView或
FindView方法进行重写,示例如下:
public class ThemeViewEngine : RazorViewEngine { public ThemeViewEngine(IRazorPageFactory pageFactory, IRazorViewFactory viewFactory, IViewLocationExpanderProvider viewLocationExpanderProvider, IViewLocationCache viewLocationCache) : base(pageFactory, viewFactory, viewLocationExpanderProvider, viewLocationCache) { } public override IEnumerable<string> AreaViewLocationFormats { get { var value = new Random().Next(0, 1); var theme = value == 0 ? "Theme1" : "Theme2"; // 可通过其它条件,设置皮肤的种类 return base.AreaViewLocationFormats.Select(f => f.Replace("/Views/", "/Views/" + theme + "/")); } } public override IEnumerable<string> ViewLocationFormats { get { var value = new Random().Next(0, 1); var theme = value == 0 ? "Theme1" : "Theme2"; // 可通过其它条件,设置皮肤的种类 return base.ViewLocationFormats.Select(f => f.Replace("/Views/", "/Views/" + theme + "/")); } } }
然后,通过修改MVcOptions的实例属性ViewEngines即可完成对视图引擎的替换,代码如下:
services.AddMvc().Configure<MvcOptions>(options => { options.ViewEngines.Clear(); options.ViewEngines.Add(typeof(ThemeViewEngine)); });
这样,系统在查找视图文件的时候,就会按照新注册的
ThemeViewEngine的逻辑来执行。
通过IViewLocationExpander来控制View路径
在MVC6中,微软还提供了另外一种新的方式来控制View文件的路径,那就是IViewLocationExpander接口,通过实现该接口即可实现自定义逻辑,并且也可以使用相关的上下文对象。示例如下:
public class ThemeViewLocationExpander : IViewLocationExpander { public void PopulateValues(ViewLocationExpanderContext context) { var value = new Random().Next(0, 1); var theme = value == 0 ? "Theme1" : "Theme2"; context.Values["theme"] = theme; } public virtual IEnumerable<string> ExpandViewLocations(ViewLocationExpanderContext context, IEnumerable<string> viewLocations) { return viewLocations.Select(f => f.Replace("/Views/", "/Views/" + context.Values["theme"] + "/")); } }
在上述自定义的
IViewLocationExpander中,实现了2个方法分别是
PopulateValues和
ExpandViewLocations,
PopulateValues方法可以让我们想
ViewLocationExpanderContext上下文中添加响应的键值对以便后续使用,通过,我们可以利用通过该上下文对象,来查找
ActionContext和
HttpContext对象,以便利用这些对象做响应的判断操作;而
ExpandViewLocations方法,只会在没有View缓存或在View缓存里找不到对应key的View文件时才会调用该方法,在该方法内,我们可以动态返回视图的位置。
最后,我们在
Startup.cs里通过修改
RazorViewEngineOptions实例对象的
ViewLocationExpanders属性,来实现注册目的,代码如下:
services.Configure<RazorViewEngineOptions>(options => { options.ViewLocationExpanders.Add(typeof(ThemViewLocationExpander)); });
同步与推荐
本文已同步至目录索引:解读ASP.NET 5 & MVC6系列相关文章推荐
- Struts2 技术内幕 读书笔记(第二章)
- Find the all applications of ubuntu
- 所谓的HTTP请求,到底都干了什么
- java基础基本数据类型对象包装
- BZOJ2818 Gcd(欧拉函数)
- 解读 Oracle 12c 的 12 个新特性
- Task 9 从用户界面和体验分析“360极速浏览器”
- iOS开发学习第十一课——动态内存分配
- SIP协议结构——SIP学习笔记(三)
- python 字典应用
- 《找出1到正整数N中出现1的次数》
- [LeetCode] Permutations II
- MvcOptions配置
- android开发小细节
- UVa 1252 Twenty Questions
- onTouchEvent构造器
- Oracle Memory Architecture(SGA,PGA)
- Ubuntu 下 Mysql 新建数据库和用户
- 把Jar文件转成exe安装文件
- 用MFC实现WebGUI--(CDHtmlDialog)