MVC和三層架構(gòu)望艺,是不一樣的苛秕。
三層架構(gòu)中,DAL(數(shù)據(jù)訪(fǎng)問(wèn)層)找默、BLL(業(yè)務(wù)邏輯層)艇劫、WEB層各司其職,意在職責(zé)分離惩激。
MVC是?Model-View-Controller店煞,嚴(yán)格說(shuō)這三個(gè)加起來(lái)以后才是三層架構(gòu)中的WEB層,也就是說(shuō)风钻,MVC把三層架構(gòu)中的WEB層再度進(jìn)行了分化顷蟀,分成了控制器、視圖骡技、實(shí)體三個(gè)部分鸣个,控制器完成頁(yè)面邏輯羞反,通過(guò)實(shí)體來(lái)與界面層完成通話(huà);而C層直接與三層中的BLL進(jìn)行對(duì)話(huà)囤萤。
所以昼窗,?.net的三層結(jié)構(gòu)中,并沒(méi)有action這個(gè)概念涛舍。
asp.netmvc?是微軟新發(fā)布的一種網(wǎng)站開(kāi)發(fā)架構(gòu)澄惊。為了解決傳統(tǒng)asp.net開(kāi)發(fā)中不能分離Model,View和Controller而設(shè)計(jì)的。
普通的網(wǎng)站為了解決可移植富雅,可維護(hù)掸驱,可擴(kuò)展等問(wèn)題,會(huì)把網(wǎng)站設(shè)計(jì)成三個(gè)獨(dú)立的模塊没佑,Model負(fù)責(zé)數(shù)據(jù)庫(kù)部分毕贼,View負(fù)責(zé)網(wǎng)頁(yè)的界面,而Controller負(fù)責(zé)界面與數(shù)據(jù)的交互及業(yè)務(wù)邏輯图筹,這樣設(shè)計(jì)的網(wǎng)站如果想設(shè)計(jì)或者重新開(kāi)發(fā)某一個(gè)模塊對(duì)其他的模塊是沒(méi)有影響的帅刀。但是asp.net的頁(yè)面后臺(tái)代碼與每個(gè)頁(yè)面代碼都是一一對(duì)應(yīng)的,業(yè)務(wù)邏輯在某些情況下不可避免的被寫(xiě)到了與View關(guān)聯(lián)的后臺(tái)代碼中远剩。這樣就不能保證View與Controller的分離扣溺,也就很難實(shí)現(xiàn)網(wǎng)站的重寫(xiě)和升級(jí)。
而在MVC中頁(yè)面代碼并不是與后臺(tái)代碼一一對(duì)應(yīng)瓜晤,而是分別被存放成Controller和View兩個(gè)部分锥余,徹底的解決了,View和Controller不能獨(dú)立的問(wèn)題痢掠。從而改善網(wǎng)站的重寫(xiě)和升級(jí)過(guò)程驱犹。
但是MVC也有其缺點(diǎn),由于在頁(yè)面代碼中不再可以使用服務(wù)器控件足画,因此給某些asp.net服務(wù)器端控件的使用帶來(lái)了麻煩雄驹,而且MVC也頁(yè)面的設(shè)計(jì)工作帶來(lái)了很多障礙。
ASP.NET?MVC?是微軟在2009年4月份發(fā)布的一種新的網(wǎng)站開(kāi)發(fā)架構(gòu)淹辞,http://msdn.microsoft.com/en-us/library/dd394709.aspx医舆,它是把傳統(tǒng)意義上的MVC開(kāi)發(fā)思想融合到了ASP.NET的開(kāi)發(fā)當(dāng)中。
那么我也來(lái)講講我對(duì)這兩者的理解吧象缀。
首先對(duì)這個(gè)題目蔬将,本身是存在問(wèn)題的,“XX結(jié)構(gòu)”與“XX模式”的區(qū)別央星?請(qǐng)問(wèn)中國(guó)社會(huì)制度與美國(guó)人生活方式有什么區(qū)別霞怀?
這兩者本身講的是不同方向與角度的問(wèn)題,在實(shí)際應(yīng)用中他們的確存在一些相似的特點(diǎn)莉给,在很多書(shū)籍中也沒(méi)有深入講解毙石,以致于造成困惑廉沮,為了更好的理解他們,姑且來(lái)說(shuō)說(shuō)區(qū)別吧徐矩。
首先N層結(jié)構(gòu)是一種軟件抽象的層次結(jié)構(gòu)废封,是對(duì)復(fù)雜軟件的一種縱向切分,每一層次中完成同一類(lèi)型的操作丧蘸,以便將各種代碼以其完成的使命作為依據(jù)來(lái)分割,以將低軟件的復(fù)雜度遥皂,提高其可維護(hù)性力喷。一般來(lái)說(shuō),層次之間是向下依賴(lài)的演训,下層代碼未確定其接口(契約)前弟孟,上層代碼是無(wú)法開(kāi)發(fā)的,下層代碼接口(契約)的變化將使上層的代碼一起變化样悟。三層結(jié)構(gòu)是N層結(jié)構(gòu)的一種拂募,是人產(chǎn)在長(zhǎng)時(shí)間使用中得出來(lái)的一種應(yīng)用場(chǎng)合廣泛的N層結(jié)構(gòu),被當(dāng)作一種典型的軟件層次結(jié)構(gòu)而廣為流傳甚至寫(xiě)入教科書(shū)窟她。
MVC模式是一種復(fù)合設(shè)計(jì)模式陈症,一種在特定場(chǎng)合用于解決某種實(shí)際問(wèn)題來(lái)得出的可以反復(fù)實(shí)踐的解決方案。巧合的是他也有三個(gè)事物組成震糖,于是乎人們就有了一種想當(dāng)然的對(duì)應(yīng)關(guān)系:展示層-View录肯;業(yè)務(wù)邏輯層-Control;持久層-Model吊说。首先MVC中的三個(gè)事物之間并不存在明顯的層次結(jié)構(gòu)论咏,沒(méi)有明顯的向下依賴(lài)關(guān)系,相反的颁井,View和Model往往是比較獨(dú)立的厅贪,而Control是連接兩者的橋梁,他們更像是橫向的切分雅宾。這樣一來(lái)就出現(xiàn)一個(gè)結(jié)果养涮,MVC中每個(gè)塊都是可以獨(dú)立測(cè)試的,而三層結(jié)構(gòu)中秀又,上層模塊的運(yùn)行測(cè)試勢(shì)必要提供下層代碼或者提供相同接口的樁单寂。相對(duì)來(lái)說(shuō),MVC復(fù)雜得多吐辙,但是結(jié)構(gòu)更清晰宣决,耦合性更低。
另外昏苏,MVC中每一塊內(nèi)部特別是Model內(nèi)部經(jīng)常被設(shè)計(jì)為多層的尊沸。在我認(rèn)為的一個(gè)良好的MVC模式構(gòu)建的結(jié)構(gòu)中威沫,Control是核心,小且較為穩(wěn)定的洼专,可以作為一個(gè)核心框架來(lái)提供棒掠,有擴(kuò)展點(diǎn),但基本上可以簡(jiǎn)單配置不需要任何代碼就可以運(yùn)行屁商。而View則可能是一套或多種可選擇的視圖引擎烟很,決定了軟件展示給用于的界面,使用時(shí)的主要工作量在于擴(kuò)展點(diǎn)以及根據(jù)需要而數(shù)量不同的視圖模板蜡镶。Model則是業(yè)務(wù)提供者雾袱,決定了軟件提供的功能,其內(nèi)部可能是一些普通的類(lèi)或者是實(shí)現(xiàn)了某些接口的類(lèi)官还,在這一塊當(dāng)中可能根據(jù)業(yè)務(wù)的不同而色彩繽紛芹橡,對(duì)于復(fù)雜的軟件可能會(huì)分成很多層,如業(yè)務(wù)邏輯層望伦、業(yè)務(wù)提供層林说、系統(tǒng)提供層、數(shù)據(jù)提供層屯伞、數(shù)據(jù)訪(fǎng)問(wèn)層等腿箩。
我經(jīng)常用于比喻MVC的例子是小時(shí)候玩的那種卡帶式游戲機(jī),Control是主機(jī)劣摇,一般來(lái)說(shuō)我買(mǎi)一個(gè)主機(jī)就行了度秘,只要他不壞,他就能一直讓我玩這一類(lèi)的游戲饵撑。View則是電視機(jī)和游戲手柄剑梳,電視機(jī)可以獨(dú)立工作,他不管輸入的是電視信號(hào)滑潘、影碟機(jī)信號(hào)還是游戲機(jī)信號(hào)垢乙,他只管顯示,而且他決定了我們看到的效果是怎么樣的语卤,如果我想要個(gè)尺寸更大的或者彩色的顯示效果追逮,我只需要買(mǎi)個(gè)相應(yīng)的電視機(jī)就行了,手柄也是可以換的粹舵,要遙桿還是帶震動(dòng)的钮孵。Model則是游戲卡帶,他絕定了我玩的是什么游戲眼滤,是魂斗羅還是超級(jí)瑪莉巴席,而且游戲機(jī)主機(jī)和電視機(jī)生產(chǎn)廠(chǎng)家永遠(yuǎn)也不知道在上面有可能會(huì)運(yùn)行什么樣的游戲∽缧瑁卡帶中可能會(huì)有游戲代碼和存儲(chǔ)單元漾唉,都根據(jù)游戲的需要而設(shè)計(jì)荧库。
有朋友提到游戲主機(jī)提供的卡帶插槽的接口,在設(shè)計(jì)中赵刑,有時(shí)也由Control提供一組接口分衫,以用于Model或View的實(shí)現(xiàn),這樣就形成了依賴(lài)般此。一般來(lái)說(shuō)這樣設(shè)計(jì)也沒(méi)有太大的問(wèn)題蚪战,只是會(huì)提高模塊間的耦合度,也會(huì)帶來(lái)一些侵入性铐懊。為了更完美屎勘,可以不用接口來(lái)提供契約,可以用配置信息(或稱(chēng)元數(shù)據(jù)信息)+反射來(lái)提供契約居扒,那么這個(gè)類(lèi)接口就可以退化到只要符合CLS就可以了,也就是普通的類(lèi)丑慎,就像現(xiàn)在的計(jì)算機(jī)接口廣泛采用USB喜喂,無(wú)論是U盤(pán)、打印機(jī)竿裂、掃描儀或者是加密狗玉吁,他們都是普通的USB設(shè)備而已。
提到USB有一個(gè)題外話(huà)腻异,模塊的可插拔性設(shè)計(jì)甚至是熱插拔設(shè)計(jì)进副,系統(tǒng)可以在不停止運(yùn)行的情況下動(dòng)態(tài)的掛載或移除模塊,動(dòng)態(tài)掛載模塊需要系統(tǒng)能夠自動(dòng)發(fā)現(xiàn)新模塊并根據(jù)自描述的信息進(jìn)行自動(dòng)配置悔常,移除可能情況更復(fù)雜一點(diǎn)影斑,需要“安全刪除硬件”類(lèi)似的功能。
在設(shè)計(jì)廣泛重用的框架時(shí)會(huì)考慮多種情況以達(dá)到更大的適應(yīng)性机打,一般項(xiàng)目中應(yīng)用MVC模式可以較為隨意矫户。