Java EE 極簡(jiǎn)教程(四):MVC 模式

MVC 模式

MVC 模式是一種軟件框架模式,被廣泛應(yīng)用在 JavaEE 項(xiàng)目的開(kāi)發(fā)中。MVC 模式很好理解,但也十分重要,在今后的 Web 應(yīng)用開(kāi)發(fā)中,我們都離不開(kāi)它。

之前,我們學(xué)習(xí)過(guò)了 Servlet、JSP,看起來(lái)它們都可以獨(dú)立完成許多功能,卻各有特點(diǎn),MVC 就提供了一種揚(yáng)長(zhǎng)避短,雙劍合璧的方法。

1.什么是 MVC

MVC 即模型(Model) 、視圖(View)、控制器(Controller)。

模型(Model)

模型是用于處理數(shù)據(jù)邏輯的部分。

所謂數(shù)據(jù)邏輯,也就是數(shù)據(jù)的映射以及對(duì)數(shù)據(jù)的增刪改查,Bean、DAO(data access object,數(shù)據(jù)訪(fǎng)問(wèn)對(duì)象)等都屬于模型部分。

視圖(View)

視圖負(fù)責(zé)數(shù)據(jù)與其它信息的顯示,也就是給用戶(hù)看到的頁(yè)面。

html、jsp 等頁(yè)面都可以作為視圖。

控制器(controller)

控制器是模型與視圖之間的橋梁,控制著數(shù)據(jù)與用戶(hù)的交互。

控制器通常負(fù)責(zé)從視圖讀取數(shù)據(jù),處理用戶(hù)輸入,并向模型發(fā)送數(shù)據(jù),也可以從模型中讀取數(shù)據(jù),再發(fā)送給視圖,由視圖顯示。

前面學(xué)到的 Servlet 便可以用作控制器。

2.為什么要用 MVC

竊以為,MVC 模式有以下三大好處。

看著舒服

前面學(xué)習(xí) Servlet 和 JSP 的時(shí)候,我們發(fā)現(xiàn)這倆東西都是功能和顯示混著來(lái),可讀性很差,而使用 MVC,Servlet 里都是邏輯代碼,JSP 都是顯示代碼,一目了然。

寫(xiě)著容易

MVC 模式有利于人員的分工合作,不同的開(kāi)發(fā)人員可各自發(fā)揮專(zhuān)長(zhǎng),同時(shí)開(kāi)發(fā)不同的部分。

改著省心

MVC 可以在一個(gè)時(shí)間內(nèi)專(zhuān)門(mén)關(guān)注一個(gè)方面,從而讓?xiě)?yīng)用程序的測(cè)試與迭代更加方便。所以,復(fù)雜的應(yīng)用程序大都會(huì)選擇使用 MVC 模式。

上述好處,用一句行話(huà)來(lái)說(shuō),就叫 “高內(nèi)聚 低耦合”。

3.設(shè)計(jì)模式與框架模式

在搜集資料的時(shí)候發(fā)現(xiàn)很多地方把 MVC 稱(chēng)為一種 “設(shè)計(jì)模式”,一開(kāi)始我覺(jué)得沒(méi)什么毛病,從字面上完全說(shuō)地通,但是仔細(xì)一想,“設(shè)計(jì)模式” 這個(gè)詞是一個(gè)術(shù)語(yǔ),是指工廠(chǎng)模式、單例模式這些東西,是不能亂用的。而 MVC,應(yīng)該被稱(chēng)作是 “框架模式”。

那么兩者有什么區(qū)別呢?

設(shè)計(jì)模式,是針對(duì) “代碼” 的,如同修筑房屋時(shí)磚瓦的層疊方式,是軟件開(kāi)發(fā)的基石。

框架模式,是針對(duì) “框架” 的,是面向某些應(yīng)用場(chǎng)景的可復(fù)用的方案,如同醫(yī)院、商場(chǎng)等不同功能建筑的布局,是比設(shè)計(jì)模式更宏觀(guān)一些的概念。

在今后的文章中,我將與大家共同學(xué)習(xí)當(dāng)前的主流框架。

4.MVC 實(shí)踐

在 JavaEE 中,最為經(jīng)典的 MVC 模式即

Bean(Model) + JSP(View) + Servlet(Controller)

假如有一個(gè)需求:實(shí)現(xiàn)編輯網(wǎng)頁(yè)上的信息并與數(shù)據(jù)庫(kù)同步

在實(shí)現(xiàn)上,可以分為以下幾步:

  1. 用 Bean 來(lái)映射數(shù)據(jù)表,并編寫(xiě)好 DAO

  2. 用負(fù)責(zé)查詢(xún)的 Servlet 調(diào)用 DAO 查詢(xún)需要編輯的內(nèi)容并發(fā)送給用于編輯的 jsp 頁(yè)面

  3. 把編輯頁(yè)面進(jìn)行修改后的值,再提交給負(fù)責(zé)更新的 Servlet 調(diào)用 DAO 更新數(shù)據(jù)庫(kù)

  4. 使用另一個(gè)負(fù)責(zé)查詢(xún)的 Servlet,把查詢(xún)出來(lái)的更新過(guò)的內(nèi)容發(fā)送給負(fù)責(zé)顯示的 JSP

這個(gè)部分本來(lái)打算自己做一遍,但之前推薦的 Java 學(xué)習(xí)網(wǎng)站 How2J 上已經(jīng)有很好的實(shí)踐教程,我就不費(fèi)勁了,直接戳下面的鏈接:

How2J 的 MVC教程

只是一個(gè)小練習(xí),看過(guò)前面的內(nèi)容的話(huà)一會(huì)兒工夫就可以做完。

之后我們將探討 Java 的主流框架,可以說(shuō)這些框架是 Java 生態(tài)的頂梁柱,是我們做 Web 開(kāi)發(fā)的利器。我們先從 Spring 說(shuō)起——

「Java EE 極簡(jiǎn)教程(五):如何理解 Spring」

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀(guān)點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 一. Java基礎(chǔ)部分.................................................
    wy_sure閱讀 4,011評(píng)論 0 11
  • 1.abstract class 和interface 有什么區(qū)別? 抽象類(lèi)可以有構(gòu)造方法 接口不行 抽象類(lèi)可以有...
    sunnysans閱讀 956評(píng)論 0 1
  • 1.Struts2.0有幾種標(biāo)簽庫(kù) 【參考答案】 UI標(biāo)簽、控制標(biāo)簽、數(shù)據(jù)標(biāo)簽、雜項(xiàng)標(biāo)簽 2.struts2必備包...
    碼記閱讀 1,726評(píng)論 0 7
  • 1、面向?qū)ο蟮奶卣饔心男┓矫?1.抽象:抽象就是忽略一個(gè)主題中與當(dāng)前目標(biāo)無(wú)關(guān)的那些方面,以便更充分地注意與當(dāng)前目標(biāo)...
    michaelgong閱讀 921評(píng)論 0 1
  • IOC 控制反轉(zhuǎn)容器控制程序?qū)ο笾g的關(guān)系,而不是傳統(tǒng)實(shí)現(xiàn)中,有程序代碼之間控制,又名依賴(lài)注入。All 類(lèi)的創(chuàng)建,...
    irckwk1閱讀 1,093評(píng)論 0 0

友情鏈接更多精彩內(nèi)容