MVC 的全名是 Model View Controller,是模型(model)--視圖(View)--控制器(Controller)的縮寫,一種軟件的設(shè)計(jì)模式.這種設(shè)計(jì)模式是一種業(yè)務(wù)邏輯/數(shù)據(jù)/界面進(jìn)行了分離的組織方法代碼,將業(yè)務(wù)邏輯聚集到一個部件里面,在改進(jìn)和個性化定制界面及用戶交互的同時,并不需要重新編寫業(yè)務(wù)邏輯. MVC 被獨(dú)特的發(fā)展起來用于映射傳統(tǒng)的輸入\處理\和輸出在一個邏輯的圖形化用戶界面的結(jié)構(gòu)中.
MVC 開始是存在于桌面程序中, M是指業(yè)務(wù)模型, V是指用戶界面, C 則是控制器.使用 MVC 的目的是將 M 和 V 的實(shí)現(xiàn)代碼分離,從而使同一個程序可以使用不同的表現(xiàn)形式.比如一批統(tǒng)計(jì)數(shù)據(jù)可以分別用柱狀圖\餅圖來表示. C 存在的目的則是確保 M 和 V 的同步,一旦 M 改變, V 應(yīng)該同步更新.
MVC 編程模式
MVC 是一種使用 MVC 設(shè)計(jì)創(chuàng)建 WEb 應(yīng)用程序的模式:
- model( 模型)表示應(yīng)用程序的核心(比如數(shù)據(jù)庫記錄列表).
- View( 視圖)顯示數(shù)據(jù)(數(shù)據(jù)庫記錄);
- Controller( 控制器)處理輸入(寫入數(shù)據(jù)庫記錄);
Model(模型)是應(yīng)用程序中用于處理應(yīng)用程序數(shù)據(jù)邏輯的部分.
通常模型對象負(fù)責(zé)在數(shù)據(jù)庫中存取數(shù)據(jù).
View(視圖)是應(yīng)用于程序中處理數(shù)據(jù)顯示的部分
通常視圖是依據(jù)模型數(shù)據(jù)創(chuàng)建的.
Controller(控制器)是應(yīng)用于程序中處理用戶交互的部分.
通常控制器負(fù)責(zé)從視圖讀取數(shù)據(jù),控制用戶輸入,并向模型發(fā)送數(shù)據(jù).
MVC 分層有助于管理負(fù)責(zé)的應(yīng)用程序,因?yàn)槟梢栽谝粋€時間內(nèi)專門關(guān)注一個方面.例如,您可以在不依賴業(yè)務(wù)邏輯的情況下專注于視圖設(shè)計(jì),同時也讓應(yīng)用程序的測試更加容易.
MVC分層同時也簡化了分組開發(fā).不同的開發(fā)人員開發(fā)視圖,控制器邏輯和業(yè)務(wù)邏輯.
框架內(nèi)容
視圖:
視圖是用戶看到并與之交互的界面.對老式的 Web 程序開發(fā)者來說,視圖就是有 HTML 元素組成的界面,在新式的 Web 應(yīng)用程序中, HTML 依舊在視圖扮演者重要的角色,但一些新的技術(shù)已層出不窮,他們包括它們包括Adobe Flash和像XHTML,XML/XSL,WML等一些標(biāo)識語言和Web services.
MVC 好處在于它能為應(yīng)用程序處理很多不同的視圖,在視圖中其實(shí)沒有真正的處理方法,不管這些數(shù)據(jù)是聯(lián)機(jī)存儲的還是一個雇員列表,作為視圖來講,它只是一種輸出數(shù)據(jù)并允許用戶操縱的方式.
模型
模型表示企業(yè)數(shù)據(jù)和業(yè)務(wù)規(guī)則,在MVC的三個部件中,模型擁有好多的處理任務(wù),例如它只能用像 EJBs 和ColdFusion Components這樣的構(gòu)件對象來處理數(shù)據(jù)庫,被模型返回的數(shù)據(jù)是中立的,就是說模型與數(shù)據(jù)格式無關(guān),這樣一個模型能為多個視圖提供數(shù)據(jù),由于應(yīng)用于模型的代碼只需寫一次就可以被多個視圖重用,所以減少了代碼的重復(fù)性。
控制器
控制器接受用戶的輸入并調(diào)用模型和視圖去完成用戶的需求,所以當(dāng)單擊Web頁面中的超鏈接和發(fā)送HTML表單時,控制器本身不輸出任何東西和做任何處理。它只是接收請求并決定調(diào)用哪個模型構(gòu)件去處理請求,然后再確定用哪個視圖來顯示返回的數(shù)據(jù)
特點(diǎn)
優(yōu)點(diǎn)
耦合性低
視圖層和業(yè)務(wù)層分離,這樣就允許更改視圖層代碼而不用重新編譯模型和控制器代碼,同樣,一個應(yīng)用的業(yè)務(wù)流程或者業(yè)務(wù)規(guī)則的改變只需要改動MVC的模型層即可。因?yàn)槟P团c控制器和視圖相分離,所以很容易改變應(yīng)用程序的數(shù)據(jù)層和業(yè)務(wù)規(guī)則。
重用性高
隨著技術(shù)的不斷進(jìn)步,需要用越來越多的方式來訪問應(yīng)用程序。MVC模式允許使用各種不同樣式的視圖來訪問同一個服務(wù)器端的代碼,因?yàn)槎鄠€視圖能共享一個模型,它包括任何WEB(HTTP)瀏覽器或者無線瀏覽器(wap),比如,用戶可以通過電腦也可通過手機(jī)來訂購某樣產(chǎn)品,雖然訂購的方式不一樣,但處理訂購產(chǎn)品的方式是一樣的。由于模型返回的數(shù)據(jù)沒有進(jìn)行格式化,所以同樣的構(gòu)件能被不同的界面使用。例如,很多數(shù)據(jù)可能用HTML來表示,但是也有可能用WAP來表示,而這些表示所需要的命令是改變視圖層的實(shí)現(xiàn)方式,而控制層和模型層無需做任何改變。由于已經(jīng)將數(shù)據(jù)和業(yè)務(wù)規(guī)則從表示層分開,所以可以最大化的重用代碼了。模型也有狀態(tài)管理和數(shù)據(jù)持久性處理的功能,例如,基于會話的購物車和電子商務(wù)過程也能被Flash網(wǎng)站或者無線聯(lián)網(wǎng)的應(yīng)用程序所重用
生命周期短
MVC 使開發(fā)和維護(hù)用戶接口的技術(shù)含量降低
部署快
使用MVC模式使開發(fā)時間得到相當(dāng)大的縮減,它使程序員集中精力于業(yè)務(wù)邏輯,界面程序員集中精力于表現(xiàn)形式上。