ASP.NET MVC框架拯救UpdatePanel

什么是“拯救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操作,于是我们在代码中就可以写如下代码:

publicclassTaskListController:AjaxController{  


...  


publicvoidCompleteTask(inttaskID){  


if(String.IsNullOrEmpty(Request.Form["deleteTask"])==false){  


InvokeAction("DeleteTask");  


return;  


}  


 



Tasktask=_taskDB.GetTask(taskID);  



if(task!=null){  


_taskDB.CompleteTask(task);  


}  


 


if(IsAjaxRequest){  


if(task!=null){  


RenderPartial("TaskView",task);  


}  


}  


else{  


RedirectToAction("List");  


}  


}  


...  


} 

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

<divid="taskList">  


<%foreach(TasktaskinTasks){%>  


<div>  


<%this.RenderPartial("TaskView",task);%>  


</div>  


<%}%>  


</div> 

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

相关推荐