摘要:ASP.NET MVC 框架
【原文位址】ASP.NET MVC Framework
【原文發表日期】 Sunday, October 14, 2007 10:41 PM
過去的幾年裡,很多人要求ASP.NET的一件事情就是對使用基於model-view-controller(模型-檢視-控制器,簡稱MVC)架構來開發web應用的內建支援。
上個週末在Austin舉行的Alt.NET大會上,我首次對我的團隊正在開發的新ASP.NET MVC 框架作了一個公開的Demo。你可以在Scott Hanselman這裡的部落格上觀看我的講座的錄影。
我們將在今年稍後發佈該框架的一個公開預覽版,然後在明年的上半年將它作為完全支援的ASP.NET特性推出。
模型-檢視-控制器(MVC)框架是什麼東西?
MVC是個將一個應用的實現分成三個元件角色的框架技術:模型,檢視和控制器。
- 在基於MVC的應用裡,Model(模型)是負責保持狀態的應用元件。這個狀態通常都持久於資料庫之中(譬如,我們也許會有一個Product(產品)類用來代表SQL中的Products資料表中的訂單資料)。
- 在基於MVC的應用裡,View(檢視)是負責顯示用戶介面的元件。這個UI通常是使用模型資料來建立的(譬如,我們也許會生成一個Product "編輯" 檢視,根據當前Product物件的狀態,顯示文字框,下拉框和復選框等)。
- 在基於MVC的應用裡,Controller(控制器)是處理用戶交互,操作模型和最終選擇用哪個檢視來顯示UI的元件。在MVC應用中,檢視只是用來顯示信息而已,是控制器來處理和回應用戶的輸入和交互的。
使用MVC方法的一個好處是,它有助於促進應用中模型,檢視,控制器間的關注的清晰分離。保持關注的清晰分離使得對應用的測試極其容易,因為不同應用元件間的契約的定義和表達是更明確的。
MVC模式也有利於促進紅/綠式測試驅動的開發 (TDD),通過它,你可以在你實際編寫應用程式碼本身之前首先實現自動化的單元測試,這些單元測試定義和核實了新程式碼的需求。
ASP.NET MVC 框架的一些簡要細節
在幾個星期後,相關程式碼可以下載之後,我將寫一些關於這個新的ASP.NET MVC 框架的深入性的教程文章(與此同時,想進一步瞭解它的最佳方式是觀看我的Alt.net講座的錄影):
這裡是關於ASP.NET MVC 框架的一些簡要細節:
- 它將促進清晰的關注分離,可測試性,和TDD。MVC框架中的所以核心契約都是基於介面的,可以輕易地通過mock來模擬(包括基於介面的IHttpRequest/IHttpResponse這些基本的東西)。你可以不用在ASP.NET行程中運行控制器(這使得單元測試很快),就單元測試你的應用。你可以使用你想使用的任何單元測試框架來做單元測試,包括NUnit, MBUnit, MS Test等等。
- 這個框架具有高度的可擴充性和可插拔性。MVC框架中所有的東西都是這樣設計的,它們可以被輕易地替換掉或者客制(譬如,你可以插入你自己的檢視引擎,路由策略(routing policy),參數序列化等等)。它還支援使用現有的依賴注入(dependency injection)和控制反轉(IoC)容器模型(Windsor, Spring.Net, NHibernate等等)。
- 它包括一個非常強大的URL映射元件,允許你使用非常乾淨的URL來建造應用。URL不需要擁有檔案擴充,是設計來輕鬆支援SEO和REST友好的命名模式的。譬如,在我上面的專案中,我可以輕鬆地把/products/edit/4映射到ProductsController類別的Edit方法上,或者把 /Blogs/scottgu/10-10-2007/SomeTopic/ 映射到BlogEngineController類別的DisplayPost方法上。
- MVC框架支援將現有的ASP.NET .ASPX, .ASCX,和 .Master 標識檔案當作檢視模板(view template)之用(這意味著你可以輕鬆地使用很多現有的ASP.NET特性,像嵌套的母版頁,<%= %>塊 ,宣告式服務控制項,模板,資料繫結,本地化等等)。但是,它不使用現有的將交互傳回伺服器的postback模型,取而代之的是,你將把用戶的所有交互轉給控制器類來調度,這有助於關注的清晰分離和提高可測試性(這也意味著,在基於MVC的檢視內沒有viewstate或page的生命週期之說)。
- ASP.NET MVC框架將完全支援象forms/windows認證,URL授權,成員/角色,輸出和資料快取,session/profile狀態管理,健康監測,配置系統,以及provider架構等等現有的ASP.NET特性。
結語
如果你正在想使用MVC方式建造你的web應用的話,我認為你會發現這個新的 ASP.NET MVC 框架選項非常乾淨,而且容易使用。它將允許你在你的應用中很輕易地保持關注分離,而且有助於進行乾淨的測試和TDD。
幾個星期之後,我將撰文說明新的MVC特性的工作原理,以及如何利用它們。
希望本文對你有所幫助,
Scott