其实这是一篇迟发布近2个月的文章。事实上在ASP.NET MVC Preview 2发布之 前我就已经将这篇文章的所有内容准备完毕了。当时想,就等Preview 2发布吧, 而真一旦Preview 2发布之后却又懒得进行移植——移植了之后却又懒 得写文章。这一拖就是近2个月,毫无长进。可能工作等其他事情的确多了些,但 是扪心自问,也并没有忙到不可开交。时间往往都是在点点滴滴间浪费的。唉, 可能是自视太高,越来越不愿意写一些普普通通的介绍性文章,导致可写的东西 大大减少。不过话说回来,其实打算写的,甚至多次说过要写得东西也并不少, 为什么就就是没有动笔呢?其实还是一个“懒”字——当 年的勤奋劲儿到哪里去了呢?
言归正传。先解释一下标题,什么是“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操作,于是我们在代码中就可以写如下代码:
public class TaskListController : AjaxController {
...
public void CompleteTask(int taskID) {
if (String.IsNullOrEmpty(Request.Form["deleteTask"]) == false) {
InvokeAction("DeleteTask");
return;
}
Task task = _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)中我们就能看到如下的代码:
<div id="taskList">
<% foreach (Task task in Tasks) { %>
<div>
<% this.RenderPartial("TaskView", task); %>
</div>
<% } %>
</div>