《電子技術應用》
您所在的位置:首頁 > 其他 > 設計應用 > 基于模型-視圖-控制器的Web應用程序框架設計
基于模型-視圖-控制器的Web應用程序框架設計
摘要: 傳統的web應用程序會在表現層包含管理用戶交互的代碼,例如:一個頁面可以決定用戶將要跳轉的下一個頁面。
Abstract:
Key words :
    傳統的web應用程序會在表現層包含管理用戶交互的代碼,例如:一個頁面可以決定用戶將要跳轉的下一個頁面。開發者經常把所有交互代碼寫在用戶界面代碼中。然而,開發者將頁面導航代碼寫入頁面代碼后,代碼會很復雜,而且難以重用、維護和擴展。對于整個應用程序來說,它的業務邏輯、控制邏輯和運行狀態等都很難被重用。在很多情況下,應用程序的運行狀態需要保持。但是如果狀態保存在某個頁面中,那么代碼必須從這個頁面中找回狀態。這樣編寫出來的代碼不夠優雅,很難得到預想的效果,而且這些不雅的代碼又影響了web頁面的擴展和重用。本文基于MVC模式,提出了一個可擴展的框架,簡化了對從web頁面獨立出來的業務邏輯代碼的處理,有利于復雜的web頁面導航和工作流處理的復用。


1 MVC設計模式
    MVC由Trygve Reenskaug提出,首先被應用在SmallTalk-80環境中,是許多交互和界面系統的構成基礎。MVC結構是為那些需要為同樣的數據提供多個視圖的應用程序而設計的,它很好地實現了數據層與表示層的分離。MVC作為一種開發模型,通常用于分布式應用系統的設計和分析中;另外,它也可用于確定系統各部分間的組織關系。對于界面設計可變性的需求,MVC把交互系統的組成分解成視圖、控制器、模型3種部件。
    視圖部件把表示模型數據及邏輯關系和狀態的信息以特定形式展示給用戶。它從模型獲得顯示信息,對于相同的信息可以有多個不同的顯示形式或視圖??刂破鞑考饕糜谔幚碛脩襞c軟件的交互操作,其職責是控制提供模型中任何變化的傳播,確保用戶界面與模型間的對應聯系;它接受用戶的輸入,將輸入反饋給模型,進而實現對模型的計算控制,是使模型和視圖協調工作的部件。模型部件保存由視圖顯示、由控制器控制的數據;它封裝了問題的核心數據及邏輯和功能的計算關系,它獨立于具體的界面表達和I/O操作。
    模型、視圖與控制器的分離,使得一個模型可以具有多個顯示視圖。如果用戶通過某個視圖的控制器改變了模型的數據,所有其它依賴于這些數據的視圖都應反映出這些變化。因此,無論何時發生了何種數據變化,控制器都會將變化通知所有的視圖,導致顯示的更新。這實際上是一種模型的變化一傳播機制。
    模型、視圖、控制器三者之間的關系和各自的主要功能如圖1所示。

2 應用框架
    為了方便地實現業務流程控制和更改,本文根據MVC設計模式,提出了一個可擴展的框架。該框架的優點是:
    1)實現了對業務流程控
制部分的包裝,便于簡化web應用程序的開發。使用框架開發web應用程序,只需依照頁面接口編寫web頁面和業務邏輯,控制部分由框架根據配置文件實現。這樣設計有利于頁面美工與程序員的協作。
    2)提高了web頁面和業務邏輯的擴展和重用,便于對業務邏輯的測試,提高了系統的靈活性。

框架的結構如圖2所示。Views和ViewManager是系統的視圖部分,其中,ViewManager負責頁面的生成與顯示。Web服務和業務邏輯組件提供應用程序的業務邏輯,屬于系統的模型部分。剩下的部分屬于系統的控制器部分,各個部分的主要功能如下:Manager給應用程序提供一個人口,根據不同的Navigator來決定新建或加載一個任務:Navigator負責管理頁面之間的跳轉,根據配置文件選擇合適的頁面,調用ViewManager激活頁面;ControllerBase和Controllers根據頁面請求調用不同的業務邏輯,返回結果;State保存應用程序的狀態以及當前顯示的頁面。

 

    此應用框架的具體工作流程如下:在Manager中啟動任務以后,實例化導航器傳遞適當的信息給導航器(Navigator)。導航器調用Configuration類從配置文件中取出配置信息,根據配置信息,創建視圖管理器(Views Manager)。然后,Manager調用Navigator的NavigateEvent事件,獲得應用程序要顯示的和下一個要顯示的頁面。此時,可以調用State類中的Save方法,將狀態保存到數據庫中。另外,導航器也可以調用適當的視圖管理器中的ActiveView方法,將視圖名字傳給視圖管理器。ActiveView方法負責創建控制器,顯示視圖。視圖顯示之后,等待用戶在界面中執行一個動作。如果用戶執行了一個動作,就通過控制器調用業務邏輯,處理后就會將結果返回頁面。
    使用框架開發應用程序可以很方便地控制和改變業務流程,此時只需要修改配置文件即可;可以實現狀態管理,保持頁面間狀態的連貫性,捕獲用戶與應用程序交互的狀態,根據保存的狀態信息,用戶可以在任何時間、地點、機器繼續未完成的操作。

3 面向應用框架的web程序開發
    汽車4S店企業資源計劃(Enterprise Resource Planning,ERP)系統業務邏輯復雜,業務流程易更改,采用本文提出的框架進行開發,結構層次清晰,便于分工協作,取得較好的效果。我們使用汽車配件采購訂單模塊,來說明框架的應用,其流程如圖3所示。

 

    在開發過程中,分別編寫需要顯示的web頁面和后臺業務邏輯,在配置文件中,使用view元素將頁面名稱與頁面代碼對應起來,在navigation部分編寫頁面的流轉。如果要修改業務流程,只需修改配置文件導航部分;另外,添加頁面也很方便,只需要在配置文件中增加頁面節點,配置頁面的流轉過程即可。
    部分流程配置代碼如下:


    通過配置文件的設置,框架可以便利地修改和擴展應用程序,實現對業務流程的控制和修改。這樣,web頁面和邏輯代碼就可以很方便地修改和復用,應用系統也具有很強的靈活性和可擴展性。


4 結論
    MVC作為一種常用的開發模型,因其實現了數據層與表示層的分離,被廣泛用于分布式系統的設計和分析,應用程序的重用度高,并易于維護和修改。很多交互性愈來愈強的傳統web應用程序開發(如PHP、ASP、JSP等),存在著代碼較為復雜、重用度低和維護擴展難度大的問題,根據MVC思想的可擴展設計框架,可有效地提高web應用程序的開發效率。

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          一本在线高清不卡dvd| 亚洲精品中文字幕在线观看| 精品动漫3d一区二区三区免费| 欧美日韩另类字幕中文| 久久国产直播| 国产欧美日韩| 欧美亚洲综合久久| 国产精品久久久久国产精品日日| 亚洲高清视频一区| 久久人人爽爽爽人久久久| 日韩午夜中文字幕| 亚洲精品1区2区| 欧美日韩精品在线观看| 91久久精品一区二区别| 在线成人av| 欧美中文字幕视频| 午夜免费日韩视频| 亚洲一区二区三区四区视频| 欧美日韩免费一区| 欧美激情成人在线视频| 欧美日韩一卡二卡| 国产精品久久久久久久久果冻传媒| 亚洲精品老司机| 亚洲美女免费精品视频在线观看| 亚洲欧美精品伊人久久| 精品999久久久| 欧美一二三区在线观看| 亚洲精品美女在线| 国产精品麻豆欧美日韩ww| 亚洲免费视频一区二区| 欧美午夜精品久久久久久久| 日韩视频在线观看免费| 亚洲日本va午夜在线影院| 国产精品午夜在线| 亚洲人成网站999久久久综合| 欧美激情第二页| 国内精品久久久久影院薰衣草| 免费在线观看精品| 欧美人妖在线观看| 久久亚洲国产精品一区二区| 欧美一区二区三区在线视频| 欧美亚洲一区三区| 亚洲精品久久久一区二区三区| 国产资源精品在线观看| 午夜精品区一区二区三| 欧美国产日韩一区二区在线观看| 韩国一区二区三区在线观看| 亚洲第一综合天堂另类专| 久久婷婷国产综合精品青草| 欧美国产三级| 国产欧美日韩精品在线| 欧美国产日韩xxxxx| 久久午夜精品一区二区| 亚洲伦理一区| 亚洲男人的天堂在线观看| 99视频超级精品| 久久久99国产精品免费| 国产喷白浆一区二区三区| 亚洲欧美综合精品久久成人| 亚洲精品一区在线观看香蕉| 极品中文字幕一区| 亚洲综合电影| 国内在线观看一区二区三区| 亚洲欧美日韩精品在线| 免费亚洲婷婷| 久久精品一区二区三区不卡牛牛| 欧美国产精品| 国内精品**久久毛片app| 欧美激情性爽国产精品17p| 久久午夜精品一区二区| 日韩视频在线免费| 香蕉尹人综合在线观看| 噜噜爱69成人精品| 欧美成人免费视频| 国产视频丨精品|在线观看| 国产字幕视频一区二区| 影音国产精品| 欧美日在线观看| 久久综合图片| 亚洲国产日韩在线| 亚洲尤物视频在线| 一本久道久久综合狠狠爱| 国产一区二区三区视频在线观看| 午夜精品久久久久久久| 国产一区二区三区奇米久涩| 亚洲一区二区三区四区视频| 一本久久精品一区二区| 9久草视频在线视频精品| 激情欧美一区二区三区在线观看| 9色porny自拍视频一区二区| 久久综合色婷婷| 久久免费高清视频| 9l国产精品久久久久麻豆| 欧美精品九九| 亚洲欧美日韩国产成人精品影院| 狂野欧美激情性xxxx| 欧美一区二区在线播放| 国产精品福利av| 亚洲欧美中文日韩在线| 在线播放精品| 国产精品日韩精品欧美精品| 狠狠色狠狠色综合系列| 欧美一区二区免费视频| 欧美日韩综合精品| 欧美日韩免费高清一区色橹橹| 性一交一乱一区二区洋洋av| 一区在线观看视频| 亚洲香蕉视频| 国语自产在线不卡| 亚洲黄色在线视频| 精品成人乱色一区二区| 久久综合五月天婷婷伊人| 午夜国产精品视频免费体验区| 欧美日韩免费区域视频在线观看| 国产精品亚洲片夜色在线| 亚洲伊人色欲综合网| 欧美日韩大片| 国产日本欧美一区二区| 国产日韩在线亚洲字幕中文| 1769国内精品视频在线播放| 欧美午夜不卡视频| 国产偷久久久精品专区| 中国av一区| 国产精品嫩草99a| 亚洲国产精品国自产拍av秋霞| 国产精品国产三级国产aⅴ入口| 激情另类综合| 美国三级日本三级久久99| 欧美黄色网络| 国产农村妇女精品一区二区| 亚洲国产精品黑人久久久| 国产欧美另类| 欧美99久久| 夜夜躁日日躁狠狠久久88av| 亚洲精品综合久久中文字幕| 欧美bbbxxxxx| 欧美大尺度在线| 欧美高清在线视频观看不卡| 久久一二三区| 午夜精品久久久久久99热| 国产欧美精品日韩区二区麻豆天美| 一本久久a久久精品亚洲| 亚洲一区二区三区高清不卡| 午夜视频久久久| 男女激情视频一区| 激情懂色av一区av二区av| 国产精品久久一级| 国产伪娘ts一区| 亚洲国产精品福利| 欧美高清自拍一区| 欧美在线播放一区二区| 亚洲综合欧美日韩| 亚洲动漫精品| 国产自产在线视频一区| 亚洲午夜在线| 最新中文字幕一区二区三区| 久久久久久久久久久成人| 99ri日韩精品视频| 久久夜色精品国产欧美乱极品| 欧美在线不卡视频| 久久精品中文字幕免费mv| 欧美视频网址| 性8sex亚洲区入口| 久久躁日日躁aaaaxxxx| 久久精品国产v日韩v亚洲| 欧美精品免费播放| 欧美亚洲一区二区在线| 亚洲人精品午夜在线观看| 亚洲伦理在线观看| 亚洲高清在线视频| 国产精品日韩精品欧美在线| 欧美精品在线免费| 欧美日韩国产色站一区二区三区| 国产亚洲精品aa午夜观看| 欧美日韩一区自拍| 亚洲国产一区二区三区青草影视| 国产偷国产偷亚洲高清97cao| 麻豆精品传媒视频| 国产精品视频男人的天堂| 欧美电影免费观看高清完整版| 欧美国产日韩在线| 国内精品久久久| 久久精品国产99国产精品| 美女脱光内衣内裤视频久久影院| 国产伦精品一区二区三区高清| 在线精品观看| 国产精品丝袜91| 亚洲国产精品嫩草影院| 亚洲福利视频一区| 尤物网精品视频| 欧美激情二区三区| 国产精品v片在线观看不卡| 欧美日韩视频一区二区三区| 久久精品国产96久久久香蕉| 亚洲精品国产精品乱码不99按摩| 国产精品v欧美精品∨日韩| 亚洲国产成人tv| 亚洲一区二区三区四区在线观看| 午夜欧美大片免费观看| 欧美精品色综合| 欧美在线一区二区| 欧美视频专区一二在线观看| 欧美久久精品午夜青青大伊人| 欧美大片网址| 国产精品一区二区久激情瑜伽| 亚洲一区3d动漫同人无遮挡| 美女91精品| 亚洲欧美综合网| 国产精品久久久久久久久久妞妞| 欧美人与禽猛交乱配视频| 亚洲黄色免费| 欧美成人精品一区| 欧美精品免费播放| 国产精品一区二区欧美| 亚洲国语精品自产拍在线观看| 欧美日本精品在线| 欧美国产欧美亚州国产日韩mv天天看完整| 日韩视频精品| 国产精品永久入口久久久| 久久久久久久久久久久久9999| 欧美一区二区国产| 一区二区在线视频观看| 欧美日韩午夜视频在线观看| 国内成人精品2018免费看| 在线播放豆国产99亚洲| 久久国产福利国产秒拍| 久久狠狠久久综合桃花| 久久一区二区三区四区五区| 精品成人国产在线观看男人呻吟| 欧美啪啪成人vr| 亚洲高清二区| 久久国产精品电影| 免费成人在线观看视频| 久久视频免费观看| 亚洲午夜在线观看视频在线| 激情综合色综合久久综合| 久久久久国色av免费观看性色| 久久精选视频| 亚洲精品日韩在线| 一本一道久久综合狠狠老精东影业| 美日韩免费视频| 欧美日本国产视频| 国产日产亚洲精品系列| 亚洲精品资源| 欧美一区2区三区4区公司二百| 尤物在线观看一区| 国产色视频一区| 欧美丝袜一区二区三区| 曰本成人黄色| 国产精品午夜国产小视频| 美女诱惑黄网站一区| 国产精品成人在线| 尤妮丝一区二区裸体视频| 欧美日韩一区二区三区视频| 久久精品综合| 亚洲自拍偷拍福利| 亚洲乱码一区二区| 91久久精品国产91久久性色tv| 国产精品久久网站| 欧美一区二区在线播放| 欧美日韩日本网| 一区二区三区精品| 欧美日韩成人一区二区| 欧美性视频网站| 国产精品va| 欧美日韩成人在线观看| 国产精品美女黄网| 欧美一区2区视频在线观看| 久久精品人人做人人综合| 国产精品国产| 精品999在线观看| 欧美午夜精品理论片a级按摩| 久久国产视频网| 欧美激情第三页| 欧美日韩精品免费在线观看视频| 亚洲国产日韩一区| 在线国产精品一区| 欧美激情在线狂野欧美精品| 国产美女精品人人做人人爽| 国产亚洲一本大道中文在线| 国产精品麻豆va在线播放| 国产日韩精品在线播放| 久久久精品国产99久久精品芒果| 久热综合在线亚洲精品| 99精品视频免费在线观看| 国产精品午夜av在线| 在线视频国内自拍亚洲视频| 亚洲伊人观看| 欧美黄色影院| 久久综合网hezyo| 久久久激情视频| 亚洲日本成人网| 亚洲一区国产一区| 欧美日韩专区| 久久久91精品国产一区二区精品| 国产精品sm| 国产一区二区三区在线观看免费| 亚洲国产精品成人一区二区| 欧美在线国产精品| 一区二区免费看| 欧美xart系列高清| 国产精品激情偷乱一区二区∴| 欧美一区二视频在线免费观看| 久久天堂成人| 亚洲第一色中文字幕| 欧美激情第9页| 久久精品国产一区二区电影| 99re8这里有精品热视频免费| 亚洲综合清纯丝袜自拍| 久久精品国产综合精品| 国内久久婷婷综合| 久久一区视频| 亚洲性人人天天夜夜摸| 欧美国产亚洲视频| 亚洲午夜av| 六月婷婷一区| 亚洲福利视频一区| 久久久久成人精品| 欧美在线免费看| 亚洲美女在线看| 欧美系列一区| 欧美日韩中文精品| 国产偷久久久精品专区| 国产欧美视频在线观看| 国产色婷婷国产综合在线理论片a| 国内成人在线| 亚洲中无吗在线| 国产精品国产a|