1. 程式人生 > >淺談MVC設計模式

淺談MVC設計模式

1、MVC設計模式:

如圖所示,MVC模式(Model-View-Controller)是軟體工程中的一種軟體架構模式,把軟體系統分為三個基本部分:模型 (Model)、檢視(View)和控制器(Controller)。MVC模式最早為Trygve Reenskaug提出,為施樂帕羅奧多研究中心(Xerox PARC)的Smalltalk語言發明的一種軟體設計模式。MVC可對程式的後期維護和擴充套件提供了方便,並且使程式某些部分的重用提供 了方便。而且MVC也使程式簡化,更加直觀。

控制器Controller:對請求進行處理,負責請求轉發; 檢視View:介面設計人員進行圖形介面設計; 模型Model:程式編寫程式應用的功能(實現演算法等等)、資料庫管理; 注意,MVC不是Java的東西,幾乎現在所有B/S結構的軟體都採用了MVC設計模式。但是要注意,MVC在B/S結構軟體並沒有完 全實現,例如在我們今後的B/S軟體中並不會有事件驅動!

2、JavaWeb與MVC

JavaWeb的經歷了JSP Model1、JSP Model1二代、JSP Model2三個時期。

2.1 JSPModel1第一代 JSP Model1是JavaWeb早期的模型,它適合小型Web專案,開發成本低!Model1第一代時期,伺服器端只有JSP頁面,所有的 操作都在JSP頁面中,連訪問資料庫的API也在JSP頁面中完成。也就是說,所有的東西都耦合在一起,對後期的維護和擴充套件極為不 利。

2.2 JSPModel1第二代 JSP Model1第二代有所改進,把業務邏輯的內容放到了JavaBean中,而JSP頁面負責顯示以及請求排程的工作。雖然第二代比 第一代好了些,但還讓JSP做了過多的工作,JSP中把檢視工作和請求排程(控制器)的工作耦合在一起了。

2.3 JSPModel2

JSP Model2模式已經可以清晰的看到MVC完整的結構了。

JSP:檢視層,用來與使用者打交道。負責接收用來的資料,以及顯示資料給使用者; Servlet:控制層,負責找到合適的模型物件來處理業務邏輯,轉發到合適的檢視; JavaBean:模型層,完成具體的業務工作,例如:開啟、轉賬等。

JSP Model2適合多人合作開發大型的Web專案,各司其職,互不干涉,有利於開發中的分工,有利於元件的重用。但是,Web 專案的開發難度加大,同時對開發人員的技術要求也提高了。

3、JavaWeb經典三層框架

我們常說的三層框架是由JavaWeb提出的,也就是說這是JavaWeb獨有的! 所謂三層是表述層(WEB層)、業務邏輯層(Business Logic),以及資料訪問層(Data Access)。

WEB層:包含JSP和Servlet等與WEB相關的內容; 業務層:業務層中不包含JavaWeb API,它只關心業務邏輯; 資料層:封裝了對資料庫的訪問細節;

注意,在業務層中不能出現JavaWebAPI,例如request、response等。也就是說,業務層程式碼是可重用的,甚至可以應用到非 Web環境中。業務層的每個方法可以理解成一個萬能,例如轉賬業務方法。業務層依賴資料層,而Web層依賴業務層!