首頁 | 社區 | 博客 | 招聘 | 文章 | 新聞 | 下載 | 讀書 | 代碼
親,您未登錄哦! 登錄 | 注冊

探索ASP.NET中Tailspin TravelUI層奧秘

打印文章

分享到:
在這里我們將從一個實例為大家分析ASP.NET MVC 2中的Tailspin Travel UI層,51CTO也向您推薦專訪微軟MVP衣明志:走進ASP.NET MVC 2框架開發。以便于大家更好的理解ASP.NET MVC。

  Tailspin Travel 是一個旅游預訂的應用程序示例,最新版本采用ASP.NET MVC 2技術構建,主要使用 DataAnnotations 驗證, 客戶端驗證和ViewModels,還展示了許多Visual Studio 2010, .NET Framework 4, 和Windows Server AppFabric的技術,參看ASP.NET MVC 2示例Tailspin Travel。

  Tailspin Travel設計的技術比較多,今天我們來看看界面(UI)上的技術,在UI層上來說主要采用的技術是ASP.NET MVC2和ASP.NET DynamicData框架。從功能上來分為向普通用戶提供的前臺頁面和管理員使用的后臺界面,前臺頁面主要實現的是旅游活動日程安排,航班,酒店,租車這幾部分采用的ASP.NET MVC 2技術,管理員用的后臺管理頁面使用的是ASP.NET DynamicData開發的,這兩種技術在網站里的應用有示范作用,對于管理員使用的后臺的訪問量不可能很大,網站的主要流量是普通用戶使用的前臺頁面,組合使用這兩個框架,可以加快網站的開發。

  組合這兩種技術,就會碰到一些的問題,第一個問題就是ASP.NET 動態數據(Dynamic Data )默認情況下,動態數據放在web應用的動態數據目錄(DynamicData)里,該目錄創建在根目錄處。你的應用需要移動的不同的位置。 在Tailspin Travel里面是“admin”目錄,動態數據就在這個目錄下,然后在Globa.asax.cs文件里

  var metaModel =newMetaModel(); metaModel.RegisterContext(contextFactory, newContextConfiguration { ScaffoldAllTables =true}); metaModel.DynamicDataFolderVirtualPath ="~/Admin/DynamicData/"

  改變admin/Dynamicdata 下文件的內容的引用到新的路徑((~/admin/Dynamicdata)

  例如:

  A、修改List.aspx和ListDetails.aspx 的注冊指令的src屬性。

  B、修改 List.aspx 和母版頁的img 的src屬性。

  C、任何自定義的必須使用新路徑的內容。

  ASP.NET 4.0有個新特性叫做“自動啟動應用程序”,自動啟動,先行初始化web應用,而不必等待外部客戶端訪問web服務器時才啟動的能力。這可以有助于你給第一個訪問者提供一個更快的回復體驗,避免撰寫定制腳本來“預熱(warm up)”服務器和準備好任何數據緩存。它可用于任何類型的ASP.NET應用,包括基于ASP.NET Web Forms和ASP.NET MVC的應用。不過要求在IIS 7.5(隨Windows 7和Windows Server 2008 R2發布)上運行 ASP.NET 4時使用。這個自動啟動特性提供了一個可控制的方式來啟動一個應用工作進程,初始化ASP.NET 應用,然后接受HTTP請求。具體參看Scott Guthrie 的文章 VS 2010 和 .NET 4.0 系列之《自動啟動ASP.NET應用》篇,Tailspin Travel有個類 Microsoft.Samples.Tailspin.Web.Infrastructure.ApplicationPreloader,就是用這個特性預先加載應用程序的緩存。

  下面我們來具體分析前臺和管理后臺:

  前臺采用ASP.NET MVC 2開發,比較簡單,主要是使用ViewModels,HtmlHelper,輸出緩存,避免CSRF攻擊,查詢方法中使用PartialView,以及 jQuery和ASP.NET Ajax配合的相關內容,可以參考 Asp.net MVC2 使用經驗,性能優化建議學習。

  下面重點來說明一下管理后臺的DynamicData的結構,先可以閱讀一下Scott Guthrie 的文章 新的ASP.NET動態數據支持:

  ASP.NET 動態數據在進行創建和更新數據時還會對所錄入的數據進行驗證,這種驗證既發生在客戶端也發生在服務器端。

  必填字段驗證。如果字段不允許為 NULL,則錄入時必須錄入數據。不過這里還有待改進,不允許為 NULL,也就成了不允許零長度字符串,而實際應用中 NULL 和零長度字符串是兩回事。縱然不夠完美,也已經為我們減輕不少工作量了。

  長度驗證。如果字段類型為 nvarchar(10),那么就不允許超過 10 個字符;如果字段類型不是 nvarchar(10),而是 varchar(10),此時六個漢字也會通過驗證,只是無法入庫罷了,會返回錯誤。

  類型驗證。比如字段是日期類型,則只允許錄入日期。

  ASP.NET 動態數據具有自動格式功能:比如 bit 類型的字段顯示為一個多選框,而標識字段不會在插入數據時顯示出來。

  ASP.NET 動態數據還具有自動識別表關聯的功能:比如產品表與產品類別表進行了關聯,那么我們在錄入產品數據的時候,ASP.NET 動態數據會自動以下拉列表的形式顯示產品類別。此功能非常不錯。

  在網站或者應用程序模板中有兩個Dynamic Data模板,一個是 "Dynamic Data實體模板(Dynamic Data Entities )"它是使用ADO.net Entity作為數據模型的,另一個是 "Dynamic Data 模板",他是使用LINQ TO SQL 來作為數據模型。Tailspin Travel 是以Entity Framework作為數據模型的。

  Dynamic Data也使用了Routing:

  routes.Add(newDynamicDataRoute("Admin//") { Constraints =newRouteValueDictionary(new{ action ="List|Edit|Details|Insert"}), Model =metaModel });

  routes.Add 的參數為一個 DynamicDataRoute 對象,而該 DynamicDataRoute 對象有一個參數為 "Admin//.aspx",另外還為該對象指定了兩個屬性值 Constraints 和 Model。把一個繼承自Route的DynamicDataRoute添加到Routing規則表中。

  Constraints =newRouteValueDictionary(new{ action ="List|Details|Edit|Insert"})

  這句表示約束,這里表示 action 只能是 List、Details、Edit、Insert 中的一個。

  可以看出,這四個Aciton是對應著DynamicData/PageTemplates文件夾中的四個頁面文件。在那文件夾中還有一個 ListDetails.aspx頁面文件,是用于"合并頁模式",就是所有的操作都會在一頁中完成。Tailspin Travel并沒有啟用這個功能。DynamicData 文件夾的名稱都是“DynamicData”。

  上面的 、 可不可以改成我們自己想要的名字呢?

  不行的,我們可以看到,上面使用的是 DynamicDataRoute 類,而不是 Route 類,DynamicDataRoute 繼承于 Route,Table 和 Action 屬性是 DynamicDataRoute 特有的。

  DynamicData/Content/GridViewPager.ascx 分頁控件。

  DynamicData/Content/FilterUserControl.ascx 在顯示表中的數據時,該控件顯示在表頭,用以過濾表中的內容,比如可以只列表產品目錄為“實用工具”的產品。

  DynamicData/CustomPages 文件夾。自定義網頁模板文件夾,可用以替換 DynamicData/PageTemplates 文件夾中的默認模板。

  DynamicData/FieldTemplates 文件夾。包含各種類型的字段在查看和創建、編輯時所呈現的控件。

  DynamicData/PageTemplates 文件夾。包含在進行查看、編輯時的頁面模板。

  Dynamic Data還有一個快速開發的基礎是腳手架,腳手架是一種機制,通過腳手架,我們不必再為每一個表的增加、查看、修改做不同的頁面,因為腳手架會自動生成這些頁面。Tailspin Travel對所有表都啟用腳手架,對所有表啟用腳手架表示公開了整個數據模型:

  metaModel.RegisterContext(contextFactory, new ContextConfiguration { ScaffoldAllTables = true });

  還可以對特定表啟用腳手架功能,這時就要將上面的ScaffoldAllTables = false,然后給模型類打標簽 [System.ComponentModel.DataAnnotations.ScaffoldTable(true)]

  自動生成的網站需要我們調整的頁面,需要創建自定義的頁面可以把它放在DynamicData/CustomPages 文件夾,在 DynamicData/CustomPages/ 下新建一個文件夾,名稱為 FlightBookings,這個名稱一定要與 Tailspin.edmx中的相應表的分部類名稱一樣。然后將 DynamicData/PageTemplates/ 下的文件復制到 DynamicData/CustomPages/FlightBookings/。

  更改新模板文件中的類名。

  比如將類名稱 List 改為 DynamicDataTest.FlightBookingsList。

  [MetadataType(typeof(CarRentalMetadata))] publicpartialclassCarRental { [ScaffoldTable(false)] privateclassCarRentalMetadata { [DisplayName("Pick up")] publicobjectRentalStart { getset} [DisplayName("Return")] publicobjectRentalEnd { getset} [DisplayName("Pick up Place")] [Required(ErrorMessage ="Please specify where you prefer to pickup the vehicle.")] publicobjectPickupPlaceId { getset} [DisplayName("Return place")] [Required(ErrorMessage ="Please specify where you prefer to return the vehicle.")] publicobjectReturnPlaceId { getset} [DisplayName("Vehicle")] [Required(ErrorMessage ="Please specify the vehicle type.")] publicobjectVehicleTypeId { getset} } } 還可以用 UIHint,DataType

  使用DisplayName更改界面的顯示,DisplayName 只能用于類、方法、屬性、索引、事件

  改變字段模板

  [MetadataType(typeof(FlightMetadata))] publicpartialclassFlight { publicFlight() { this.Id =Guid.NewGuid(); } [DisplayName("Flights")] privateclassFlightMetadata { [ScaffoldColumn(false)] publicobjectId { getset} [Required] publicobjectAirplaneType { getset} [UIHint("Time")] publicobjectDepartureTime { getset} [UIHint("Time")] [DataType(DataType.Time)] publicobjectArrivalTime { getset} [DisplayName("Departure Airport")] publicobjectDepartureAirport { getset} [DisplayName("Arrival Airport")] publicobjectArrivalAirport { getset} } } DynamicData

  非常的靈活,Tailspin Travel用來對付管理后臺的開發方面具有非常高的效率,在前臺使用MVC2保證性能,在UI界面的開發方面非常值得借鑒的一種模式。

本欄文章均來自于互聯網,版權歸原作者和各發布網站所有,本站收集這些文章僅供學習參考之用。任何人都不能將這些文章用于商業或者其他目的。( Pfan.cn )

編程愛好者論壇

本欄最新文章

北京快三开奖结果走势图一定牛