基于模型-視圖-控制器的Web應用程序框架設計
傳統的web應用程序會(huì )在表現層包含管理用戶(hù)交互的代碼,例如:一個(gè)頁(yè)面可以決定用戶(hù)將要跳轉的下一個(gè)頁(yè)面。開(kāi)發(fā)者經(jīng)常把所有交互代碼寫(xiě)在用戶(hù)界面代碼中。然而,開(kāi)發(fā)者將頁(yè)面導航代碼寫(xiě)入頁(yè)面代碼后,代碼會(huì )很復雜,而且難以重用、維護和擴展。對于整個(gè)應用程序來(lái)說(shuō),它的業(yè)務(wù)邏輯、控制邏輯和運行狀態(tài)等都很難被重用。在很多情況下,應用程序的運行狀態(tài)需要保持。但是如果狀態(tài)保存在某個(gè)頁(yè)面中,那么代碼必須從這個(gè)頁(yè)面中找回狀態(tài)。這樣編寫(xiě)出來(lái)的代碼不夠優(yōu)雅,很難得到預想的效果,而且這些不雅的代碼又影響了web頁(yè)面的擴展和重用。本文基于MVC模式,提出了一個(gè)可擴展的框架,簡(jiǎn)化了對從web頁(yè)面獨立出來(lái)的業(yè)務(wù)邏輯代碼的處理,有利于復雜的web頁(yè)面導航和工作流處理的復用。
1 MVC設計模式
MVC由Trygve Reenskaug提出,首先被應用在SmallTalk-80環(huán)境中,是許多交互和界面系統的構成基礎。MVC結構是為那些需要為同樣的數據提供多個(gè)視圖的應用程序而設計的,它很好地實(shí)現了數據層與表示層的分離。MVC作為一種開(kāi)發(fā)模型,通常用于分布式應用系統的設計和分析中;另外,它也可用于確定系統各部分間的組織關(guān)系。對于界面設計可變性的需求,MVC把交互系統的組成分解成視圖、控制器、模型3種部件。
視圖部件把表示模型數據及邏輯關(guān)系和狀態(tài)的信息以特定形式展示給用戶(hù)。它從模型獲得顯示信息,對于相同的信息可以有多個(gè)不同的顯示形式或視圖。控制器部件主要用于處理用戶(hù)與軟件的交互操作,其職責是控制提供模型中任何變化的傳播,確保用戶(hù)界面與模型間的對應聯(lián)系;它接受用戶(hù)的輸入,將輸入反饋給模型,進(jìn)而實(shí)現對模型的計算控制,是使模型和視圖協(xié)調工作的部件。模型部件保存由視圖顯示、由控制器控制的數據;它封裝了問(wèn)題的核心數據及邏輯和功能的計算關(guān)系,它獨立于具體的界面表達和I/O操作。
模型、視圖與控制器的分離,使得一個(gè)模型可以具有多個(gè)顯示視圖。如果用戶(hù)通過(guò)某個(gè)視圖的控制器改變了模型的數據,所有其它依賴(lài)于這些數據的視圖都應反映出這些變化。因此,無(wú)論何時(shí)發(fā)生了何種數據變化,控制器都會(huì )將變化通知所有的視圖,導致顯示的更新。這實(shí)際上是一種模型的變化一傳播機制。
模型、視圖、控制器三者之間的關(guān)系和各自的主要功能如圖1所示。
2 應用框架
為了方便地實(shí)現業(yè)務(wù)流程控制和更改,本文根據MVC設計模式,提出了一個(gè)可擴展的框架。該框架的優(yōu)點(diǎn)是:
1)實(shí)現了對業(yè)務(wù)流程控
制部分的包裝,便于簡(jiǎn)化web應用程序的開(kāi)發(fā)。使用框架開(kāi)發(fā)web應用程序,只需依照頁(yè)面接口編寫(xiě)web頁(yè)面和業(yè)務(wù)邏輯,控制部分由框架根據配置文件實(shí)現。這樣設計有利于頁(yè)面美工與程序員的協(xié)作。
2)提高了web頁(yè)面和業(yè)務(wù)邏輯的擴展和重用,便于對業(yè)務(wù)邏輯的測試,提高了系統的靈活性。
評論