系統(tǒng)中對(duì)Razor的支持包括兩部分,其中之一就是自定義RazorViewEngine
一、自定義RazorViewEngine
在Global.asax.cs的Application_Start方法中,注冊(cè)了自定義視圖引擎:
//remove all view engines ViewEngines.Engines.Clear(); //except the themeable razor view engine we use ViewEngines.Engines.Add(new ThemeableRazorViewEngine());
ThemeableRazorViewEngine繼承ThemeableBuildManagerViewEngine,
ThemeableBuildManagerViewEngine繼承ThemeableVirtualPathProviderViewEngine
ThemeableVirtualPathProviderViewEngine繼承VirtualPathProviderViewEngine,達(dá)到對(duì)虛擬路徑解析的目的。
說到ASP.NET MVC中的視圖引擎(ViewEngine),就不得不說IView和IViewEngine這兩個(gè)接口,要實(shí)現(xiàn)自定義的視圖引擎就必須要實(shí)現(xiàn)這兩個(gè)接口:
IView接口:IView是對(duì)MVC結(jié)構(gòu)中View對(duì)象的抽象,此接口只有一個(gè)方法:void Render(ViewContext viewContext, TextWriter writer);Render方法將頁面HTML寫入到Writer中供瀏覽器顯示;
IViewEngine接口:IViewEngine接口的職責(zé)是尋找View對(duì)象,編寫自己的視圖引擎時(shí)可以繼承自IViewEngine并重寫該類的FindView和FindPartialView方法,這兩個(gè)方法返回一個(gè)ViewEngineResult表示搜索結(jié)果。
ASP.NET MVC提供了兩個(gè)實(shí)現(xiàn)了IViewEngine接口的類:VirtualPathProviderViewEngine和WebFormViewEngine。VirtualPathProviderViewEngine類實(shí)現(xiàn)了FindView和FindPartialView這兩個(gè)方法,用于根據(jù)指定的路徑和格式來搜索頁面文件,并且提供了Cache機(jī)制來緩存數(shù)據(jù)(由于使用的是ASP.NET Cache,依賴于HttpContext,所以無法在WebService或WCF項(xiàng)目中使用)。
VirtualPathProviderViewEngine尋找頁面的時(shí)候,具體從哪些路徑下進(jìn)行尋找其實(shí)是根據(jù)該類中的這三個(gè)屬性來決定的:MasterLocationFormats、ViewLocationFormats、PartialViewLocationFormats,修改這三個(gè)屬性可以給我們的視圖引擎分配自定義的搜索路徑和文件格式。
二、自定義類WebViewPage<TModel>
此類表示呈現(xiàn)使用ASP.NET Razor語法的視圖所需的屬性和方法。
所以每一個(gè)視圖都應(yīng)該繼承此類。但是我們?cè)陧?xiàng)目中是看不到此繼承的,默認(rèn)情況下Razor會(huì)讓視圖繼承自System.Web.Mvc.WebViewPage<TModel>基類。也可以通過修改視圖目錄(每一個(gè)asp.net mvc項(xiàng)目下面都有一個(gè)~/Views/目錄)下的web.config文件來更改默認(rèn)基類,NopCommerce就是使用此方法實(shí)現(xiàn)自定義WebViewPage類的。除此之外也可以在視圖文件中引入命名空間,但這種方法比較繁瑣,除非一個(gè)項(xiàng)目中有個(gè)別視圖需要自定義WebViewPage。