MVC簡介
MVC(Model-View-Controller) 模式的基本思想是數(shù)據(jù)币砂,顯示和處理相分離绵估。模型(Model)負(fù)責(zé)數(shù)據(jù)管理,視圖(View)負(fù)責(zé)數(shù)據(jù)顯示亲族,控制器(Controller)負(fù)責(zé)業(yè)務(wù)邏輯和響應(yīng)策略崔慧。
用戶界面邏輯的更改往往比業(yè)務(wù)邏輯頻繁拂蝎,尤其是在基于Web的應(yīng)用程序中。例如惶室,可能添加新的用戶界面頁温自,或者可能完全打亂現(xiàn)有的頁面布局。對顯示的更改皇钞,盡可能地不要影響到數(shù)據(jù)和業(yè)務(wù)邏輯悼泌。
為什么要用MVC
目前大部分Web應(yīng)用都是將數(shù)據(jù)代碼和表示混在一起。經(jīng)驗比較豐富的開發(fā)者會將數(shù)據(jù)從表示層分離開來鹅士,但這通常不是很容易做到的券躁,它需要精心的計劃和不斷的嘗試。MVC從根本上強制性的將它們分開掉盅。盡管構(gòu)造MVC應(yīng)用需要一些額外的工作也拜,但它帶來的好處是無庸質(zhì)疑的
圖解
視圖(View):
視圖是用戶看到并與之交互的界面。對老式的Web應(yīng)用程序來說趾痘,視圖就是由HTML元素組成的界面,在新式的Web應(yīng)用程序中永票,HTML依舊在視圖中扮演著重要的角色卵贱,但一些新的技術(shù)已層出不窮,它們包括Adobe Flash和象XHTML侣集,XML/XSL键俱,WML等一些標(biāo)識語言和Web services。如何處理應(yīng)用程序的界面變得越來越有挑戰(zhàn)性世分。MVC一個大的好處是它能為你的應(yīng)用程序處理很多不同的視圖编振。在視圖中其實沒有真正的處理發(fā)生,不管這些數(shù)據(jù)是聯(lián)機存儲的還是一個雇員列表臭埋,作為視圖來講踪央,它只是作為一種輸出數(shù)據(jù)并允許用戶操縱的方式。
模型 (Model):
模型表示企業(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ù)性。
控制器(Controller):
控制器接受用戶的輸入并調(diào)用模型和視圖去完成用戶的需求痹束。所以當(dāng)單擊Web頁面中的超鏈接和發(fā)送HTML表單時检疫,控制器本身不輸出任何東西和做任何處理。它只是接收請求并決定調(diào)用哪個模型構(gòu)件去處理請求祷嘶,然后確定用哪個視圖來顯示模型處理返回的數(shù)據(jù)屎媳。
現(xiàn)在我們總結(jié)MVC的處理過程,首先控制器接收用戶的請求论巍,并決定應(yīng)該調(diào)用哪個模型來進行處理烛谊,然后模型用業(yè)務(wù)邏輯來處理用戶的請求并返回數(shù)據(jù),最后控制器用相應(yīng)的視圖格式化模型返回的數(shù)據(jù)嘉汰,并通過表示層呈現(xiàn)給用戶
優(yōu)點
MVC的優(yōu)點體現(xiàn)在以下幾個方面:
(1) 有利于團隊開發(fā)分工協(xié)作和質(zhì)量控制丹禀,降低開發(fā)成本。
(2) 可以為一個模型在運行時同時建立和使用多個視圖。變化-傳播機制可以確保所有相關(guān)的視圖及時得到模型數(shù)據(jù)變化双泪,從而使所有關(guān)聯(lián)的視圖和控制器做到行為同步持搜。
(3) 視圖與控制器的可接插性,允許更換視圖和控制器對象焙矛,而且可以根據(jù)需求動態(tài)的打開或關(guān)閉葫盼、甚至在運行期間進行對象替換。
(4) 模型的可移植性村斟。因為模型是獨立于視圖的贫导,所以可以把一個模型獨立地移植到新的平臺工作。需要做的只是在新平臺上對視圖和控制器進行新的修改蟆盹。
(5) 潛在的框架結(jié)構(gòu)孩灯。可以基于此模型建立應(yīng)用程序框架逾滥,不僅僅是用在設(shè)計界面的設(shè)計中峰档。