ASP.NET MVC 視圖(二)
10年積累的網站設計制作、成都網站建設經驗,可以快速應對客戶對網站的新想法和需求。提供各種問題對應的解決方案。讓選擇我們的客戶得到更好、更有力的網絡服務。我雖然不認識你,你也不認識我。但先網站設計制作后付款的網站建設流程,更有漣水免費網站建設讓你可以放心的選擇與我們合作。前言
上篇中對于視圖引擎只是做了簡單的演示,對于真正的理解視圖引擎的工作過程可能還有點模糊,本篇將會對由MVC框架提供給我們的Razor視圖引擎的整個執(zhí)行過程做一個粗略的講解,目的在于讓大家對Razor視圖引擎的執(zhí)行過程留個印象以便聯(lián)想的思考到視圖引擎的作用以及視圖在MVC框架中的表示。
ASP.NETMVC 視圖
l 自定義視圖引擎
l Razor視圖引擎執(zhí)行過程
l Razor視圖的依賴注入、自定義視圖輔助器
l 分段、分部視圖的使用
l Razor語法、視圖輔助器
Razor視圖引擎執(zhí)行過程
大家看過上個篇幅對試圖引擎的執(zhí)行過程有個大概的了解,而Razor視圖引擎的執(zhí)行則更為詳細,不會像上篇這么粗糙,來看一下示意圖,圖1.
圖1
圖1中所示的是Razor視圖引擎中的對象結構的繼承關系,對于圖1右邊部分的意思則是表示視圖引擎是從系統(tǒng)的ViewEngines.Engines也就是ViewEngineCollection集合類型中取出來的,在ViewEngineCollection下面部分則是表示Razor試圖引擎的一個繼承關系示意圖。
圖2
我們先來看紅色指針所指部分的流程:
在我們使用ViewResult作為控制器方法的返回類型的時候,MVC框架會首先執(zhí)行ViewResult中的FindView()方法,而在ViewResult的FindView()中并不是由它自身來執(zhí)行查找視圖的任務的,MVC框架很多管閑事,它會干擾進來。它會從系統(tǒng)的ViewEngines.Engines也就是ViewEngineCollection集合類型中取出來Razor試圖引擎來執(zhí)行查找視圖的任務【圖1中例舉了Razor視圖引擎的繼承結構】。
隨之由VirtualPathProviderViewEngine類型來執(zhí)行查找視圖的任務,實際在這里根據視圖名稱查找的并不是我們定義的xxxx.cshtml視圖文件,而是由xxxx.cshtml文件編譯成的cs文件,這些cs文件中表示對應視圖的代碼,這個在本篇的最后會有講解,那么這些cs文件是在什么時候生成的呢?是在請求到達控制器的時候,好事的MVC框架就會把View文件夾下或者是對應區(qū)域的View文件夾下,關于這個控制器文件夾中的所有視圖都會統(tǒng)統(tǒng)的編譯生成為cs文件。
扯蛋扯遠了回到主題,在VirtualPathProviderViewEngine類型找到視圖后【cs文件】,便會讓RazorViewEngine類型來生成視圖處理類,也就是實現(xiàn)了IView的RazorView類型了并且封裝到ViewEngineResult類型實例中。
下面我們就來說明下藍色指針所指部分的流程:
這個時候MVC框架會調用ViewEngineResult類型中的View屬性中的Render()方法,實則就是剛剛上面說的RazorView類型實例中的方法。
然后我們看圖2,在Render()方法的執(zhí)行過程中,首先是由BuildManagerWrapper類型根據視圖的路徑去讀取文件并且動態(tài)編譯過后返回視圖cs文件中所表示的類型,這里BuildManagerWrapper類型是MVC框架的內部類型是實現(xiàn)了內部的IBuildManager接口,BuildManagerWrapper類型的意思就是對于動態(tài)編譯功能的一個封裝,實則就是調用System.Web.Compilation.BuildManager里的功能。
回到主題,類型生成好了過后是由DefaultViewPageActivator類型來生成視圖所對應的C#類型【System.Web.Mvc.WebViewPage<dynamic>】,最后通過RazorView類型中的RenderView()方法來對剛剛我們生成好的視圖對應的C#類型進行基礎性的賦值,比如說從ViewContext類型參數(shù)中獲取ViewData、ViewBag等等數(shù)據信息【ViewContext類型繼承自ControllerContext,所以你懂的】進行賦值。
最后會被WebPageRenderingBase類型的對象來做渲染處理,這部分內容就不做闡述了。
以上就是多Razor視圖引擎也就是ViewResult類型的處理過程,說的很粗糙大家見諒希望能對大家對于視圖的理解上有所幫助。
下面來說一下由MVC框架對于視圖文件編譯后的cs文件,要眼見為實嘛對吧。
首先我們看一下某個視圖的運行的結果,圖3.
圖3
而對應的視圖代碼【cshtml文件中的代碼】,如代碼1-1.
代碼1-1
@{ ViewBag.Title = "Index"; } <h3>Index</h3> @foreach (varitem in Model) { <h4>ID: @item.ID Name:@item.Name</h4> }
那么在請求達到控制器過后編譯后的視圖cs文件存在哪了呢?
在系統(tǒng)的C:\Users\你系統(tǒng)的用戶名\AppData\Local\Temp\Temporary ASP.NET Files中,當然了并不是在這個文件夾下面,而是在會這里又生成一些其它的亂七八糟名稱的文件夾,找一個即可。
我就是在C:\Users\你系統(tǒng)的用戶名\AppData\Local\Temp\Temporary ASP.NETFiles\root\19537580\dfb4a136文件夾下找的,當然了cs文件的命名也不是對應著視圖名稱的,一般是由App_Web開頭命名的。經過一番查找找到了對應代碼1-1的cs文件了,來看一下,代碼1-2
代碼1-2
#pragma checksum "E:\JY\JY\Action\ASP.NETMVC\SystemCase\MyMvcApplication\MvcApplication\Views\iocdemo\Index.cshtml""{406ea660-64cf-4c82-b6f0-42d48172a799}""11002EF3288CEAD21A96AC68FD35C045" //------------------------------------------------------------------------------ //<auto-generated> // 此代碼由工具生成。 // 運行時版本:4.0.30319.1008 // // 對此文件的更改可能會導致不正確的行為,并且如果 // 重新生成代碼,這些更改將會丟失。 //</auto-generated> //------------------------------------------------------------------------------ namespace ASP { usingSystem; usingSystem.Collections.Generic; usingSystem.IO; using System.Linq; usingSystem.Net; usingSystem.Web; usingSystem.Web.Helpers; usingSystem.Web.Security; usingSystem.Web.UI; usingSystem.Web.WebPages; usingSystem.Web.Mvc; usingSystem.Web.Mvc.Ajax; usingSystem.Web.Mvc.Html; usingSystem.Web.Routing; public class _Page_Views_iocdemo_Index_cshtml: System.Web.Mvc.WebViewPage<dynamic> { #line hidden public_Page_Views_iocdemo_Index_cshtml() { } protectedASP.global_asax ApplicationInstance { get{ return((ASP.global_asax)(Context.ApplicationInstance)); } } public override voidExecute() { #line 1 "E:\JY\JY\Action\ASP.NETMVC\SystemCase\MyMvcApplication\MvcApplication\Views\iocdemo\Index.cshtml" ViewBag.Title = "Index"; #line default #line hidden WriteLiteral("\r\n<h3>Index</h3>\r\n"); #line 6 "E:\JY\JY\Action\ASP.NETMVC\SystemCase\MyMvcApplication\MvcApplication\Views\iocdemo\Index.cshtml" foreach (var item in Model) { #line default #line hidden WriteLiteral(" <h4>ID: "); #line 8 "E:\JY\JY\Action\ASP.NETMVC\SystemCase\MyMvcApplication\MvcApplication\Views\iocdemo\Index.cshtml" Write(item.ID); #line default #line hidden WriteLiteral(" Name:"); #line 8 "E:\JY\JY\Action\ASP.NETMVC\SystemCase\MyMvcApplication\MvcApplication\Views\iocdemo\Index.cshtml" Write(item.Name); #line default #line hidden WriteLiteral("</h4>\r\n"); #line 9 "E:\JY\JY\Action\ASP.NETMVC\SystemCase\MyMvcApplication\MvcApplication\Views\iocdemo\Index.cshtml" } #line default #line hidden } } }
想必看到這里大家清楚了吧,對于視圖文件cshtml、vbhtml等等最后在運行時編譯成的類型System.Web.Mvc.WebViewPag,至于類型后面的泛型類型是dynamic類型是對應于普通視圖,而強類型視圖編譯后的類型就會將此處的dynamic類型替換成強類型視圖的ViewModel類型了,最后說一下對于#line的意思可問度娘,是便于我們調試用的。
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
本文題目:ASP.NETMVC視圖(二)-創(chuàng)新互聯(lián)
網頁地址:http://muchs.cn/article46/dgceeg.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供面包屑導航、網站排名、做網站、網站導航、網站設計公司、用戶體驗
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)