系統(tǒng)中對Razor的支持包括兩部分,其中之一就是自定義RazorViewEngine
一、自定義RazorViewEngine
在Global.asax.cs的Application_Start方法中,注冊了自定義視圖引擎:
//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á)到對虛擬路徑解析的目的。
說到ASP.NET MVC中的視圖引擎(ViewEngine),就不得不說IView和IViewEngine這兩個接口,要實(shí)現(xiàn)自定義的視圖引擎就必須要實(shí)現(xiàn)這兩個接口:
IView接口:IView是對MVC結(jié)構(gòu)中View對象的抽象,此接口只有一個方法:void Render(ViewContext viewContext, TextWriter writer);Render方法將頁面HTML寫入到Writer中供瀏覽器顯示;
IViewEngine接口:IViewEngine接口的職責(zé)是尋找View對象,編寫自己的視圖引擎時可以繼承自IViewEngine并重寫該類的FindView和FindPartialView方法,這兩個方法返回一個ViewEngineResult表示搜索結(jié)果。
ASP.NET MVC提供了兩個實(shí)現(xiàn)了IViewEngine接口的類:VirtualPathProviderViewEngine和WebFormViewEngine。VirtualPathProviderViewEngine類實(shí)現(xiàn)了FindView和FindPartialView這兩個方法,用于根據(jù)指定的路徑和格式來搜索頁面文件,并且提供了Cache機(jī)制來緩存數(shù)據(jù)(由于使用的是ASP.NET Cache,依賴于HttpContext,所以無法在WebService或WCF項(xiàng)目中使用)。
VirtualPathProviderViewEngine尋找頁面的時候,具體從哪些路徑下進(jìn)行尋找其實(shí)是根據(jù)該類中的這三個屬性來決定的:MasterLocationFormats、ViewLocationFormats、PartialViewLocationFormats,修改這三個屬性可以給我們的視圖引擎分配自定義的搜索路徑和文件格式。
二、自定義類WebViewPage<TModel>
此類表示呈現(xiàn)使用ASP.NET Razor語法的視圖所需的屬性和方法。
所以每一個視圖都應(yīng)該繼承此類。但是我們在項(xiàng)目中是看不到此繼承的,默認(rèn)情況下Razor會讓視圖繼承自System.Web.Mvc.WebViewPage<TModel>基類。也可以通過修改視圖目錄(每一個asp.net mvc項(xiàng)目下面都有一個~/Views/目錄)下的web.config文件來更改默認(rèn)基類,NopCommerce就是使用此方法實(shí)現(xiàn)自定義WebViewPage類的。除此之外也可以在視圖文件中引入命名空間,但這種方法比較繁瑣,除非一個項(xiàng)目中有個別視圖需要自定義WebViewPage。
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com