由於上面一個項目使用的是ASP.NET4.0 MVC3.0,在招人的時候發現很多人有聽說過MVC,但是卻是沒用過,對MVC也只是一知半解,最近想給團隊成員做一個系統的解說,讓大家都可以學習一下ASP.NET MVC3.0。但是由於前兩天安裝了Windows8和VS11,所以寫些關於ASP.NET 4.5和MVC4.0的一些東東,順便復習一下MVC3.0。這里涉及的有些東西都是MVC3.0的,有些會和MVC4.0進行對照,由於我也是剛剛接觸ASP.NET MVC4.0對於它的改進也不甚了解,如果錯誤歡迎批評指正。同時也希望大家共同進步,最主要的是我的團隊成員能夠更多的理解ASP.NET MVC3.0或MVC4.0的開發。
首先聲明有關本系列(暫時計划寫系列,希望是比較完整性的文章,但世事難料,不敢保證,(*^__^*))可能有些內容翻譯或摘自網絡,如有侵犯你的版權,請聯系我,我會最快時間內進行改寫或糾正。閑話不多說,我們來看一下正題,首先當然是建立一個MVC項目。打開VS11,可以從Win8開始頁面的Metro程序格中打開,也可以到你的文件夾中尋找,不過我的已經把他固定在了任務欄里了。
這個沒有什么區別,和VS2010一樣,選擇一下MVC Application就可以了。 和ASP.NET MVC3.0相比,多了幾個項目,一個是WebAPI,Mobile Application,以及Single Page Application。其他的項目我們先不管,選擇Internet Application,由於他使用的是NuGet發布的所以第一次可能創建項目會有點慢,不過沒關系,以后就不會了,第一次耐心點。
在VS11中,默認的調試服務器使用的時IIS Express,這個比那個虛擬的好用多了,因為速度快多了,只是個人感覺,不知道各位達人是否有同感呢?我們首先來看一下允許情況,用調試按鈕,可以看到調試按鈕下面多了好多個選項?包括你機子所裝的所有瀏覽器和Page Inspector(相當好用的調試工具)。
這里我們選擇使用頁面調試工具,初次使用我們需要激活一下,其實也就是設置一下Web.config的配置節點,如下圖所示,具體修改就是激活一下設計時,可以打開web.config看看就知道了。
運行結果如下圖所示,圖中也指出了各個窗口相關的內容,讓我們可以了解一下頁面調試機制和相關功能,從圖中可以了解到,屏幕大是有好處的,如果有條件,可以使用兩個屏幕,在win8中很容易設置,右邊中的“設備”就有第二個屏幕的選項。
相比ASP.NET MVC3.0在4.0中有很多的改變,首先JQuery以及其他的一些腳本版本進行了升級,當然也移除了微軟自己的AJAX庫。估計是用的人太少了吧,在頁面上多了個“聯系我們”,其他沒什么改變。但是在代碼中有很多的變化,值得我們研究研究,首先讓我們來打開Global.asax的代碼,可以看到改變了不少。 1 using System;
3 using System.Configuration;
4 using System.Data.Entity;
5 using System.Data.Entity.Infrastructure;
6 using System.Linq;
7 using System.Web;
8 using System.Web.Http;
9 using System.Web.Mvc;
10 using System.Web.Optimization;
11 using System.Web.Routing;
12
13 namespace MVC4.WebSite
14 {
15 // Note: For instructions on enabling IIS6 or IIS7 classic mode,
16 // visit http://go.microsoft.com/?LinkId=9394801
17
18 public class MvcApplication : System.Web.HttpApplication
19 {
20 public static void RegisterGlobalFilters(GlobalFilterCollection filters)
21 {
22 filters.Add( new HandleErrorAttribute());
23 }
24
25 public static void RegisterRoutes(RouteCollection routes)
26 {
27 routes.IgnoreRoute( " {resource}.axd/{*pathInfo} ");
28
29 routes.MapHttpRoute(
30 name: " DefaultApi ",
31 routeTemplate: " api/{controller}/{id} ",
32 defaults: new { id = RouteParameter.Optional }
33 );
34
35 routes.MapRoute(
36 name: " Default ",
37 url: " {controller}/{action}/{id} ",
38 defaults: new { controller = " Home ", action = " Index ", id = UrlParameter.Optional }
39 );
40 }
41
42 protected void Application_Start()
43 {
44 AreaRegistration.RegisterAllAreas();
45
46 // Use LocalDB for Entity Framework by default
47 Database.DefaultConnectionFactory = new SqlConnectionFactory( " Data Source=(localdb)\v11.0; Integrated Security=True; MultipleActiveResultSets=True ");
48
49 RegisterGlobalFilters(GlobalFilters.Filters);
50 RegisterRoutes(RouteTable.Routes);
51
52 BundleTable.Bundles.RegisterTemplateBundles();
53 }
54 }
55 }
其中多了WebAPI節點的路由配置,這是給WebAPI使用的,其中一個可選項的枚舉也不同,后面的章節我們會單獨來學習WebAPI相關內容,這里就不多說了。在應用程序啟動的方法中,默認的配置了Entity Framework數據庫配置實例,這個框架在我們的項目中沒有使用到,因為之前我聽說性能不能很好。而且他的編程習慣也不適合我,所以就沒用他,如果有人用過他來開發企業網站或軟件可以交流交流,傳授一下經驗。最后一個不同的就是BundleTable的代碼,根據我的了解這個主要是用於WebAPI的優化,也應該屬於MVC4.0的新特性,主要是WebAPI在HTTP傳輸JavaScript和CSS的時候移除一些不必要的空白和字符和一些最佳優化的性能提升。從他所在的程序集名稱也可以看出是屬於性能優化方面的,而且是MVC4.0的時候才有的。
打開布局頁面我們會發現,URL路徑轉換也改變了使用的是System.Web.Optimization.BundleTable.Bundles.ResolveBundleUrl方法,而不是使用Url.Content了,當然也可以使用,可能那個性能會比較優化,這個需要等待進一步的證實。如果我們修改了Page Inspector所涉及的頁面內容,他就會有提示是否需要刷新流量頁面,點擊有就可以對其直接顯示,如下圖。
還有一大改進就是已經使用HTML5來進行布局了,一般使用FireFox和Chrome的人都會與時俱進,可是IE6的用戶量也是相當龐大的一個數據量,所以我們希望"Modernizr"能夠幫助我們使用HTML5的威力。這一篇文章主要是對ASP.NET MVC4.0一個認識,以及對VS11的一個認識,雖然VS11得界面很丑,但是功能確實很先進。