ASP.NET MVC框架拯救UpdatePanel
创始人
2024-04-19 07:51:18
0

什么是“拯救UpdatePanel for ASP.NET MVC框架”呢?ASP.NET AJAX中的UpdatePanel相信大家都有所了解。可惜的是,ASP.NET MVC框架的诞生“毁灭”了大量基于PostBack的控件,首当其冲地可能就是UpdatePanel了。如果没有 PostBack,UpdatePanel就失去了全部作用,甚至不如一些绑定控件,至少它们还能够用于展示。为UpdatePanel长吁短叹之后,我们不禁又开始怀念UpdatePanel的优势:“透明”。在UpdatePanel的帮助下,实现AJAX操作对于开发人员几乎完全透明。我们要做的仅仅是将需要AJAX更新的内容用UpdatePanel包装起来,一切都是那么优雅。

我们能否在ASP.NET MVC中拯救UpdatePanel呢?也许是可以的吧,但这更像是一个“不可能完成的任务”。我不是传说中的阿汤哥,因此重新为ASP.NET MVC量身定制一个AJAX解决方案似乎更为可行。虽然我们不会苛求一个新生事物从诞生开始就趋向完美,但即使只是一个原型,它也必须严格遵守的一些原则:

不得破坏MVC中的协议(协作,职责等等)

对开发人员尽可能地透明

Nikhil Kothari曾经提出了他在ASP.NET MVC框架下的AJAX解决方案。如果您还不了解他的做法,那么我先在这里进行一点概括。Nikhil扩展了Controller使之支持一种Ajax操作,于是我们在代码中就可以写如下代码:

  1. publicclassTaskListController:AjaxController{  
  2. ...  
  3. publicvoidCompleteTask(inttaskID){  
  4. if(String.IsNullOrEmpty(Request.Form["deleteTask"])==false){  
  5. InvokeAction("DeleteTask");  
  6. return;  
  7. }  
  8.  
  9. Tasktask=_taskDB.GetTask(taskID);  
  10. if(task!=null){  
  11. _taskDB.CompleteTask(task);  
  12. }  
  13.  
  14. if(IsAjaxRequest){  
  15. if(task!=null){  
  16. RenderPartial("TaskView",task);  
  17. }  
  18. }  
  19. else{  
  20. RedirectToAction("List");  
  21. }  
  22. }  
  23. ...  

与AjaxController类似,Nikhil也为ViewPage和ViewControl提供了一些扩展方法,因此目前在View(List.aspx)中我们就能看到如下的代码:

  1. divid="taskList">  
  2. <%foreach(TasktaskinTasks){%>  
  3. <div>  
  4. <%this.RenderPartial("TaskView",task);%>  
  5. </div>  
  6. <%}%>  
  7. </div> 

在View和Controller中都存在对于RenderPartiel方法的调用,它们的作用就是向客户端输出一个“Partial Template”生成的HTML代码。而在ASP.NET MVC的默认配置中,Partial Template即为User Control。而在TaskView这个Partial Template中可以看到一些辅助方法:

  1. divid="taskItem<%=Task.ID%>"class="taskPanel">  
  2. <%Ajax.Initialize();%>  
  3. <%this.RenderBeginAjaxForm(  
  4. Url.Action("CompleteTask"),  
  5. new{  
  6. Update="taskItem"+Task.ID,  
  7. UpdateType="replace",  
  8. Completed="endUpdateTask"});%>  
  9.  
  10. inputtype="hidden"name="taskID"value="<%=Task.ID%>"/>  
  11. inputtype="submit"class="completeButton"name="completeTask"value="Done!"/>  
  12. inputtype="submit"class="deleteButton"name="deleteTask"value="Delete"/>  
  13. <span><%=Html.Encode(Task.Name)%></span>  
  14.  
  15. <%this.RenderEndForm();%>  
  16. <%Ajax.RenderScripts();%>  
  17. </div> 


这些辅助方法的作用是生成一些触发AJAX更新的标签及脚本,当用户点击RenderBeginAjaxForm与RenderEndForm方法生成的tag之间的提交按钮时,网页将会向服务器端发出一个AJAX请求,而服务器端的Action并最终会通过RenderPartial方法输出一个Partial Template生成的HTML。服务器端最终输出的HTML将会被替换或添加到页面的某个元素内。这就形成了一个AJAX效果。这个解决方案从某些方面看上去很酷,尤其是生成的代码可以添加到某个元素中,而不单单是如同UpdatePanel的替换,例如Nikhil在他的例子中就使用了这个特性实现了一个添加功能。不过如果使用之前提出的原则来衡量的话,似乎这个解决方案并不十分理想。以上介绍ASP.NET MVC框架拯救UpdatePanel

【编辑推荐】

  1. ASP.NET的AsyncState参数
  2. ASP.NET MVC执行异步Action
  3. 概述ASP.NET MVC框架
  4. ASP.NET MVC中使用UpdataModel方法
  5. ASP.NET MVC的Action方法

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...