MVC開始版本
在最初的 JSP網頁中,像數據庫查詢語句這樣的數據層代碼和像HTML這樣的表示層代碼是混在一起,更甚者還會在里面寫一些Java代碼來做業務邏輯的處理。(在 jsp中<%一寫就可以在里面敲Java代碼)雖然經驗比較豐富的開發者會將數據從表示層分離開來,但這樣的良好設計通常并不是很容易做到的。
這種老的架構模式,前后端互相依賴,耦合性過高。而且寫這種代碼還需要你對前端有一定的掌握程度,可以說是十分的痛苦。
但這種模式也要一些自己的好處,架構簡單,適合小型項目的開發
o 但 jsp要做的事情太多了不是很便于維護
o 加上現在的開發中 jsp用的也越來越少了,這種模式也就慢慢淡出了我們的視線
MVC升級版時代
正是因為 mvc開始版本的種種弊端,Servlet + JSP + Java Bean 的開發模式就誕生了,也就是我們的Mvc升級版,使用了這種架構模式后,我們會將程序分為三個部分 Model、View、Controller
模型(Model):
· 數據模型層,這一層即負責對數據的封裝,也負責對數據進行一些邏輯操作。
· Model 有對數據直接訪問的權力,例如對數據庫的訪問。
· Model不依賴 View和 Controller,也就是說, Model 不關心它會被如何顯示或是如何被操作。
· Model 中數據的變化一般會通過一種刷新機制來實現。
· 為了實現這種機制,那些用于監視此 Model 的 View 必須事先在此 Model 上注冊,從而,View 可以了解在數據 Model 上發生的改變。
視圖(View):
· 負責數據模型的展示,一般就是我們看到的用戶界面。
· 在 View 中一般沒有程序上的邏輯
· 為了實現 View 上的刷新功能,View 需要訪問它監視的數據模型(Model),因此應該事先在被它監視的數據中注冊。
控制器(Controller):
· 起到不同層面間的組織作用,用于控制應用程序的流程。它處理事件并作出響應。“事件”包括用戶的行為和數據 Model 上的改變。
這樣做有哪些好處呢
盡管構造MVC應用程序需要一些額外的工作,但是它帶給我們的好處是毋庸置疑的
首先,多個 View 能共享一個 Model 。如今,同一個Web應用程序會提供多種用戶界面,例如用戶希望既能夠通過瀏覽器來收發電子郵件,還希望通過手機來訪問電子郵箱。這就要求Web網站同時能提供Internet界面和WAP界面。在MVC設計模式中, Model 響應用戶請求并返回響應數據,View 負責格式化數據并把它們呈現給用戶,業務邏輯和表示層分離,同一個 Model 可以被不同的 View 重用,所以大大提高了代碼的可重用性。
· MVC三個模塊相互獨立,改變其中一個不會影響其他兩個,所以依據這種架構思想能構造良好的低耦合構件。
· Controller 提高了應用程序的靈活性和可配置性。Controller 可以用來連接不同的 Model 和 View 去完成用戶的需求,也可以為構造應用程序提供強有力的手段。
o 給定一些可重用的 Model 、 View 和Controller 可以根據用戶的需求選擇適當的 Model 進行處理,然后選擇適當的的 View 將處理結果顯示給用戶。
· MVC 架構強調職責分離,所以在發展 MVC 應用時會產生很多文件,在 IDE (集成開發環境) 不夠成熟時它會是個問題,但在現代主流 IDE 都能使用類別對象的信息來組織代碼編輯的情況下,多文件早已不是問題。
· MVC 架構會要求開發者進一步思考應用程序的架構 (Application Architecture),而非用大雜燴的方式開發應用程序,對于應用程序的生命周期以及后續的可擴展與可維護性而言有相當正面的幫助。
· MVC 職責分離也帶來了一個現代軟件工程要求的重要特性:可測試性,MVC-based 的應用程序在良好的職責分離的設計下,各個部分可獨立行使單元測試,有利于與企業內的自動化測試、持續集成與持續發行流程集成,減少應用程序改版部署所需的時間。
MVC架構應用程序的目的就是希望打破以往應用程序使用的大雜燴編寫方式,并間接誘使開發人員以更高的架構導向思維來思考應用程序的設計,因此對于一個剛入門的初學者來說,架構導向的思考會有一定的門檻,需要較多的實現與練習才能具備相應的能力,大多數的初學者還是較習慣于大雜燴式的程序撰寫,所以可能會對 MVC 模式抱持著排斥或厭惡的心態。
然而 MVC 是有助于應用程序長遠的發展,雖然大雜燴式的程序也可以用來發展長生命周期的應用程序,但是相較于 MVC,大雜燴式的程序在可擴展性和可維護性 (尤其是可測試性) 上會遠比 MVC 復雜很多,相反的,MVC 模式的應用程序是在初始開發時期必須先思考并使用軟件架構,使得開發時期會需要花較多心力,但是一旦應用程序完成后,可擴展性、可維護性和可測試性反而會因為 MVC 的特性而變得容易。
MVC 模式在已有眾多優秀框架的現代,早就已經沒有不適合小型應用的問題,小型的應用還是可以由 MVC Framework 的應用來獲取 MVC 的優點,同時它也能作為未來小型應用擴展到大型應用時的基礎與入門磚。若一開始就想要做大型應用,那么 MVC 模式的職責分離以及要求開發的架構思考會更適合大型應用的開發。
更多關于“Java培訓”的問題,歡迎咨詢千鋒教育在線名師。千鋒已有十余年的培訓經驗,課程大綱更科學更專業,有針對零基礎的就業班,有針對想提升技術的好程序員班,高品質課程助理你實現java程序員夢想。