夜雨竹林
落叶无声

http://www.cnblogs.com/RChen/archive/2010/02/03/1662874.html

 

首先,System.Web.Mvc.Ajax 名称空间下,有一个静态辅助类,叫做 AjaxExtensions.

他有一系列 ActionLink 方法的重载形式,已供在 html 里使用,方便的生成各种 ajax 链接.
最终,这些链接都生成类似下面的一个 js 调用:
(其中 {0} 的位置是传入的叫做 ajaxOptions 的 JSON 格式的参数集合)

Sys.Mvc.AsyncHyperlink.handleClick(this, new Sys.UI.DomEvent(event), {0});

那么,接下来把目光转到相应的 js 文件。

在下列文件中,
<项目名>\Scripts\MicrosoftMvcAjax.debug.js

依次追踪函数调用如下:
AsyncHyperlink.handleClick()
_asyncRequest();
Sys.Mvc.MvcHelpers._onComplete()

在 _onComplete() 函数中,会判断 response 的 header, 决定是执行 js 还是更新元素:

if ((contentType) && (contentType.indexOf('application/x-javascript') !== -1)) {
    eval(ajaxContext.get_data());
}
else {
    Sys.Mvc.MvcHelpers.updateDomElement(ajaxContext.get_updateTarget(), ajaxContext.get_insertionMode(), ajaxContext.get_data());
}

在这之后,有一些简单的代码用来隐藏 loading panel,以及调用 onSuccess 或 onFail 的回调函数等,比较
容易理解,不多说了。

以上是普通 ajax 超链接的情况,下面简单的看一下 ajax form.
在 AjaxExtensions 辅助类中,同样有一堆 BeginForm 方法,以供在 html 中使用。
他们调用了上面 js 文件中的下列函数:

Sys.Mvc.AsyncForm.handleSubmit()

而这个函数的作用,是把 form 里的所有字段值序列化为一个字符串,然后仍然是通过上述的 _asyncRequest()
js 函数来执行,原理类似。
下面是关键的跟踪代码:

Sys.Mvc.AsyncForm.handleSubmit = function Sys_Mvc_AsyncForm$handleSubmit(form, evt, ajaxOptions) {
    evt.preventDefault();
    var body = Sys.Mvc.MvcHelpers._serializeForm(form);
    Sys.Mvc.MvcHelpers._asyncRequest(form.action, form.method || 'post', body, form, ajaxOptions);
}

 

posted on 2010-03-22 23:54  夜雨竹林  阅读(302)  评论(0编辑  收藏  举报