成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

淺談ASP.NET MVC框架

開發 后端
本文介紹ASP.NET MVC框架,面向ASP.NET MVC特有的AJAX解決方案,也有一些額外的問題需要考慮。

服務器端的實現原理并不復雜,不過作為解決方案的另一個關鍵部分,如何在客戶端觸發一個AJAX提交也是一個值得思考的話題。 UpdatePanel的方式可謂“全自動”:頁面加載時將會把服務器端的Trigger信息輸出至客戶端,然后在客戶端截獲form的提交事件,并通過 UniqueID或DOM結構等方式來判斷這次提交是否該轉化為AJAX方式。不過在一個ASP.NET MVC頁面中幾乎不會出現產生PostBack的元素,相反會有大量的普通鏈接,它們才是AJAX更新的主要截獲目標。

為此我提供了一些JavaScript代碼,截獲一個鏈接原本的目標地址并將其轉化為一個AJAX請求。我在這里通過示例中的代碼來展示這種使用方式(這個示例源于Brad Abrams提供的ASP.NET MVC示例,不過我舍棄了Northwind數據庫與Entity Framework,取而代之的是XML數據以及自定義的簡單Model。此外,我也將其移植到ASP.NET MVC框架的0416 Build中):

  1. <%foreach(varcategoryinthis.ProductCategories)  
  2. {%>  
  3. <li>  
  4. <%=Html.ActionLink<ProductsController>(  
  5. c=>c.List(category,1),  
  6. category,  
  7. new{onclick="mvcAjax.get(this,event)"})%>  
  8. </li><%  
  9. }%> 

這段代碼來自分類列表頁。與AJAX改進之前的代碼相比,唯一的區別就是額外指定了元素的onclick事件(加粗部分)。在onclick事件執行中,這個鏈接默認的跳轉行為將被取消,取而代之的是一個AJAX請求,請求的目標便是ProductsController中名為List的Action。

我們可以使用上面的方式應對普通鏈接,那么又該如何將一個客戶端from的提交行為也變成AJAX操作呢?以下依舊是示例中的代碼:

  1. formmethod="post" 
  2. action="<%=Url.Action("Update",new{id=this.Product.ProductID})%>" 
  3. onsubmit="mvcAjax.submit(this,event);">  
  4.  
  5. <table>  
  6. <tr>  
  7. <td>Name:</td>  
  8. <td><%=Html.TextBox("Name",this.Product.Name)%></td>  
  9. </tr>  
  10. ...  
  11. </table>  
  12.  
  13. inputtype="submit"value="Save"/>  
  14. </form> 

在截獲了form的submit事件之后,客戶端將會收集該form中的所有input、select等值,組成一個請求的body,并且以HTTP POST的方式發出一個AJAX請求。余下的事情和之前就沒有什么區別了。

與UpdatePanel相比,MvcAjaxPanel的客戶端截獲方式可謂“純手工”,但是我并不認為這會造成什么問題。ASP.NET MVC強調的就是職責分離,而這種分離并不僅僅體現在代碼上,也體現在開發人員的職責上。在開發ASP.NET MVC應用程序時,負責View的是前端開發工程師,對他們來說JavaScript與AJAX可謂是再熟悉不過的技術。在合時的地方手動編寫一些 JavaScript調用反而會讓他們得到無比的自由性。例如在之前的代碼示例中,調用mvcAjax.get或mvcAjax.submit方法時完全可以在前后自由地加入額外操作或者條件判斷。這就不會像使用UpdatePanel時,如果需要使用JavaScript提交一個AJAX更新,還需要借助不登大雅之堂的trick。

也正因為如此,Nikhil提出的解決方案非常不錯,它能夠和前臺開發人員的自定義邏輯進行靈活地結合。此外,通過閱讀ASP.NET MVC框架0416 Build的代碼,我發現在新版本的ASP.NET MVC中似乎將會內置這種AJAX解決方案了——不過這也的確符合微軟的一貫做法,不是嗎?

這個AJAX解決方案原型的使用方式和工作原理已經描述完了,如果您對其具體實現感興趣,或者想親自嘗試一下,可以下載文章末尾的附件。附件中的解決方案包含三個項目,MvcAjax為提供MvcAjaxPanel的項目,而MvcWebApp是一個普通的ASP.NET MVC示例程序,而MvcAjaxWebApp自然就是添加AJAX效果之后的結果了。在示例中,我還在Master Page中定義的菜單(即頁面左側的菜單)里顯示了一塊當前時間,這是為了體現MvcAjaxPanel的“一次提交,多處更新”的特點。

不過需要強調的是,這僅僅是個原型。或者說這只是一種實現上嘗試,在很多細節方面并沒有作太多追求。如果要成為一個完善的AJAX解決方案,還需要作大量的改進。例如:

提供一些客戶端的hook供前臺開發人員使用(如提交前、接受后、或者處理一個提交還沒有返回,客戶端就發起另一個請求的情況等等)。

更強大的功能,更好的開發體驗(如客戶端觸發機制)

異常處理

支持腳本

支持跳轉(Redirection)

此外,作為面向ASP.NET MVC特有的AJAX解決方案,也有一些額外的問題需要考慮。最典型的問題之一就是在使用ASP.NET MVC時很少使用模板控件,而更多的使用頁面中的循環,那么如何讓MvcAjaxPanel在循環內容生效?我也產生過一些想法,但是如果要真正確定下來最終的實現方式,很多東西還需要進一步思考。如果您對于這個AJAX解決方案有什么建議或其他任何想法,也請盡快告訴我。

***再說一件有趣的事情:在我實現了這個原型之后的某一天,忽然意識到這個控件似乎不光可以為ASP.NET MVC框架使用,也能夠用于普通的WebForms應用程序。這真是一個令人意外的發現。

【編輯推薦】

  1. ASP.NET的AsyncState參數
  2. ASP.NET MVC執行異步Action
  3. 概述ASP.NET MVC框架
  4. ASP.NET MVC中使用UpdataModel方法
  5. ASP.NET MVC的Action方法
責任編輯:佚名 來源: IT專家網
相關推薦

2009-07-23 15:44:39

ASP.NET MVC

2009-07-24 13:20:44

MVC框架ASP.NET

2009-07-20 10:53:59

ASP.NET MVC

2009-07-22 10:09:59

ASP.NET MVC

2009-12-07 09:23:05

ASP.NET MVC

2009-07-22 10:34:37

ActionInvokASP.NET MVC

2009-07-22 13:08:55

拯救UpdatePanASP.NET MVC

2010-06-23 15:44:03

ASP.NET MVC

2009-07-20 12:42:04

MvcContrib.ASP.NET MVC

2009-03-13 10:58:48

ASP.NetMVC框架編程

2014-06-30 09:22:38

ASP.NETBootstrap

2009-07-20 15:30:11

ASP.NET應用

2009-07-22 16:11:43

ASP.NET AJA

2009-07-24 10:52:42

ASP.NET ISA

2011-01-28 09:45:29

ASP.NET MVC

2009-12-21 10:05:10

ASP.NET MVC

2009-07-31 12:43:59

ASP.NET MVC

2009-07-20 12:59:53

ASP.NET MVCASP.NET框架的功

2009-06-01 10:23:31

asp.net mvcasp.net mvc.net mvc框架

2009-07-24 10:55:00

asp.net mvc
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 福利视频一区二区 | 最近中文字幕在线视频1 | 日韩视频一区二区 | 国产成人综合在线 | 国产一区精品 | 亚洲伊人久久综合 | 国产精品视频不卡 | 国产91精品久久久久久久网曝门 | 久久综合av | 日韩一区二区三区视频 | 欧美三级成人理伦 | 欧美黄色绿像 | 国产精品视频一区二区三区 | 99精品视频在线观看 | 国产精品一区二区视频 | 国产伦精品一区二区 | 精品免费在线 | 大久| 国产精品成人在线播放 | 国产免费一区二区三区免费视频 | av一二三区 | 麻豆精品国产91久久久久久 | 国产日韩欧美激情 | 在线亚洲免费视频 | 久久久久久久久久爱 | 亚洲精品乱码久久久久久久久 | 自拍视频精品 | 欧美一级做a爰片免费视频 国产美女特级嫩嫩嫩bbb片 | 午夜影院在线观看 | 欧美视频在线免费 | 成人国产免费视频 | 美国a级毛片免费视频 | 欧美在线一区二区三区 | 精品视频一区二区三区在线观看 | 午夜精品网站 | 欧美中文字幕一区 | 黑人精品 | 欧美日韩久久精品 | 欧美日韩亚洲系列 | 日韩精品专区在线影院重磅 | 特一级黄色毛片 |