當前位置:編程學習大全網 - 源碼下載 - 怎樣區分webform和mvc

怎樣區分webform和mvc

MVC與WebForm最大的區別

使用ASP.NET MVC框架,創建默認項目,第壹直觀感覺就是地址都是Rewrite過的。對源碼和配置文件稍加分析不難看出,MVC使用了httpModules來攔截地址請求,具體用到了System.Web.Routing類庫(MVC2中,MVC1怎麽用的忘記了。)而這部分類庫被包裝在.NET Framework3.5 SP1中,MVC2需要SP1支持也就理所當然了。SP1提供的System.Web.Routing類庫可以方便地進行地址請求攔截,對編碼處理方面也很優秀。UrlRoutingModule類攔截請求,在這之前,Application_Start的時候,會給RouteTable的全局對象壹個攔截的設置。而這個設置使用RouteCollection對象進行保存,MVC對這個類進行了擴展——RouteCollectionExtensions。這些可以不考慮,接下來,當用戶訪問頁面時,UrlRoutingModule類攔截請求,在RouteTable中查看是否符合規則,符合的話,就會調用MvcHandler,這個調用在httpHandlers配置節點被註冊,條件是地址符合“*.mvc”規則。MvcHandler的ProcessRequest方法就會調用Controller來執行。事實上整個過程都是黑盒子,用戶感覺不到。在Controller中某方法執行後,返回結果,再進入具體的aspx頁面。

分析了MVC的工作工程,就可以對比其與WebForm的區別了。我們知道,MVC模式的業務被放置到Controller中去執行,而aspx頁面只負責顯示。那麽在MVC中的業務實際執行時間被提前到了HttpMolde中,而WebForm的請求只在httpHandler容器中被執行。也就是說MVC中Controller與View的分離是使用的ASP.Net請求管道隔離的,這樣的話無疑在不影響效率(壹次請求,而Response.Redirect是二次請求)的情況下達成了代碼的邏輯層次的分離。

圖1 MVC工作模型

MVC工作的優點是顯然的,更加有利於理解分層邏輯,把握代碼的層次感。Controller到aspx頁面之間的過程,已經被框架隔離。至於Controller或者View頁面與Model調用的過程,還是需要自己來把握。ASP.NET的MVC框架實現了Controller代碼的單獨管理。

而看WebForm開發模型,則只在HttpHandler容器中執行,對其進行分層,在大的方面缺乏支持,而只能依靠邏輯上分離。並不是不能分離,而是由壹定的局限性。HttpHandler的攔截,是跟訪問後綴名有關的。當請求壹個頁面時,那就是壹個Handler,而WebForm模型實現顯示與邏輯分離,才有的是WinForm的事件驅動。顯然,事件必須被註冊到頁面裏,比如Button1_Click這樣的代碼。而在Button1_Click執行之前,Page_Load方法會被執行。顯示代碼被寫入Page_Load方法中,那麽就會造成需要寫額外的廢代碼,比如if (!Page.IsPostBack)這樣的判定。而在Button1_Click執行後需要顯示的部分,則比較難處理,寫出另壹個方法,也是必須要在Button1_Click裏調用的。替代的解決方案是使用Response.Redirect,在壹個aspx頁面中處理邏輯,處理完就跳轉到另外壹個顯示的頁面。這樣做的壞處是,在兩個頁面中數據很難***享,而跳轉是通過標記302來實現,因此多壹次請求。而另外還可以通過Server.Execute,Server.Transfer或者Context.RewritePath這樣的處理方式,則兩個頁面轉換是在服務器端完成,可以***享數據,可以說和MVC框架的處理方式大同小異,缺點是需要手動配置這些重新定向的屬性。

從以上分析可以看出,MVC框架具有很強的優越性,而WebForm也不是壹無是處,在簡單的應用中更加容易開發。WebForm也是可以實現和MVC壹樣的分層方式,只是處理時需要多寫壹些代碼而已。而我認為,在用WebForm開發分層遇到的最大問題是頁面與頁面之間數據的傳遞問題,而掌握好WebForm中使用服務器端跳轉的應用技巧(Server.Execute,Server.Transfer或者Context.RewritePath)進行開發就可以解決數據傳輸問題,用WebForm開發比MVC框架更容易理解,不會產生復雜的配置,也是壹個很不錯的選擇

  • 上一篇:如何制作定制的ubuntu鏡像
  • 下一篇:中國到泰國源代碼
  • copyright 2024編程學習大全網