特別提醒:本文編寫時間是 2013 年,請根據目前 .NET 發展接收你所需的知識點。
PS:MVC出來很久了,工作上一直沒機會用。出於興趣,工作之餘我將展開對MVC的深入學習,通過博文來記錄所學所得,並希望能得到各位園友的斧正。
本文目錄
理解一般意義上的MVC模式
MVC模式(Model-View-Controller)是軟體工程中的一種軟體架構模式,把軟體系統分為以下三個基本部分:
- 模型(Model):模型用於封裝與應用程式的業務邏輯相關的資料以及對資料的處理方法。“模型”有對資料直接訪問的權力,例如對資料庫的訪問。“模型”不依賴“檢視”和“控制器”,也就是說,模型不關心它會被如何顯示或是如何被操作。
- 檢視(View):檢視能夠實現資料有目的的顯示。在檢視中一般沒有程式上的邏輯。
- 控制器(Controller) :控制器起到不同層面間的組織作用,用於控制應用程式的流程。它處理事件並作出響應。“事件”包括使用者的行為和資料模型上的改變。
上面的定文來自維基百科。根據上面的定文和我個人的理解,我畫了下面這樣一張表示MVC各部分關係的圖:
注意,不同的平臺和不同的語言框架對MVC的定義各有不同,並沒有一個明確的定義。但大體上,MVC模式中的每個部分是分工明確、界定清晰的。運算元據的邏輯只存在於模型中,呈現資料的邏輯只存在於檢視中,處理使用者的請求和輸入只存在於控制器中。不管應用程式有多大、處於哪段生命週期,這種清晰的關注點分離(separation of concerns)的MVC模式讓我們的應用程式更容易維護和擴充套件。
理解領域模型
領域模型(Domain Model) 是對領域內的概念類或現實世界中物件的視覺化表示。又稱概念模型、領域物件模型、業務物件模型。它專注於分析問題領域本身,發掘重要的業務領域概念,並建立業務領域概念之間的關係。 領域模型是描述業務用例實現的物件模型,它是對業務角色和業務實體之間應該如何聯絡和協作以執行業務的一種抽象。
對於MVC應用程式,領域模型是一個非常重要的部分。在某種行業內,我們根據現實世界的實體、相關的操作和規則來建立模型(Model)。對於C#程式來說,領域模型就是一組封裝現實世界物件的C#型別(類、結構等);領域內對物件的一些操作(或者叫處理),則是定義在C#型別中的方法(Method);而領域內對物件操作的一些規則就是方法內部的邏輯處理,比如C#中的屬性讀寫器的get和set方法對讀寫類成員的控制。舉個例子:
比如銀行這個領域,個人的“銀行帳戶”可以建成一個模型。每個賬戶都有“銀行卡消費”這項操作,即銀行賬戶模型下的一個方法。“不能透支消費”是對這個帳戶使用銀行卡的約束規則,這個規則就是定義在銀行卡消費方法內部的邏輯處理。
上面說的雖然有點抽象,但還是很容易理解的。而我對領域模型的理解只能到這裡了,朋友們好好體會吧。總之,在MVC應用程式中,我們要有這樣一個概念:要通過Model運算元據,或新增一項操作,或給某項操作新增、改變一個規則,這些都是在改變應用程式的領域模型。
理解ASP.NET中的MVC
概括的講ASP.NET MVC有如下特點:
- 通過把專案分成model view和controller,這種任務分離(亦稱關注點分離),使得複雜專案更加容易維護,另外測試驅動元件使得應用程式也更加容易測試。
- 可擴充套件的簡便的框架。mvc框架被設計用來更輕鬆的移植和定製功能。你可以加入自己的檢視引擎,url重寫策略,過載action方法等。mvc也支援Dependency Injection (DI) 和 Inversion of Control (IOC)。強大的url重寫機制讓你更方便的建立容易理解和可搜尋的url。url可以不包含任何副檔名,並且可以重寫url使其對搜尋引擎更加友好。
- 對現有的asp.net程式的支援,可以使用asp.net現有的頁面標記、使用者控制元件、模板頁、資料繫結等等。
- ……
在ASP.NET MVC中,控制器通常是繼承System.Web.Mvc.Controller的類。控制器中類的每個公共方法被稱為Action方法。ASP.NET路由系統內部根據請求的URL和路由配置呼叫對應的Action方法,完成領域模型的操作後,再選擇一個檢視呈現給客戶端。下圖顯示了ASP.NET MVC中Controller、Model和View之間的關係:
另外,ASP.NET MVC框架可以使用任何被.NET支援的資料庫、ORM框架和其他工具。
對於初學者,我覺得對ASP.NET MVC的概念瞭解到這就差不多了。如果想更好的理解ASP.NET中 MVC的概念建議訪問MSDN文件。
如果你是新手,為了幫助理解,建議你到網上找幾個幾個簡單的Demo做做。
參考:《Pro ASP.NET MVC 3 Framework》