其实其中大部分都是老生常谈的js代码了,不过我们可以一窥google的编码风格:尽可能压缩信息量,变量名能用一个字母的绝不用两个,函数名一概都是两个字母的,函数内的会车是没有的,缩进也是没有的。虽然代码没有特地加密,但是如此处理一番之后也就没什么可读性了。还好系统的关键字是不能缩水的,顺着xml控件的名字我们可以揪出来跟AJAX异步加载数据相关的几个关键函数:
function vb()
{
var a=null;
if(r)
{
var b=fG?"Microsoft.XMLHTTP":"Msxml2.XMLHTTP";
try{a=new ActiveXObject(b)}
catch(c)
{
q(c);
alert("您需要启用活动脚本功能和activeX 控件。")
}
}else{
a=new XMLHttpRequest();
if(!a){;alert("此浏览器不支持 XMLHttpRequest。")}
}
return a
}
//emu注释 构造XML控件并返回给调用者
function ot(a,b){;
try{
a.send(b)
}
catch(c)
{
q(c);
if(c.number==-2146697208){
alert("请确保 Internet Explorer 的”语言”设置部分不是空白。")}
}
}
//emu注释 执行发送数据操作 a:XML控件 b:要发送的数据
function Wf(a,b,c){
Da(3);
b=Ld(b);
Hf(a,b,c)
}
//emu注释 a:XML控件 b:访问的url c:回调函数 Da是验证参数长度的函数
//Ld是一个url转换加工的函数,主要处理url自带的CGI参数和翻页的页数等
function Hf(a,b,c){
Da(3);
a.onreadystatechange=c;
a.open("GET",b,true);
ot(a,null)
}
//emu注释 不发送数据直接请求资源 a:XML控件 b:访问的url c:回调函数
function nt(a,b,c,d){
Da(4);
a.onreadystatechange=d;
a.open("POST",b,true);
ot(a,c)
}
//emu注释 发送数据并请求资源 a:XML控件 b:访问的url c:要发送的数据 d:回调函数
基本上就这么多了,很失望吧,没有什么新鲜的东西。发送http请求之后它又怎么处理返回的xml的呢?事实上他没有处理。他所处理的仅仅是最基本 responseText,而cgi则直接生成js脚本到客户端回调(用eval运行),或者生成文本信息。这就是为什么gmail可以轻松跨域几个浏览器了。
作为最受推崇的一个AJAX应用,却几乎没有用到xml。像这样用xml控件来收发文本信息后在页面上展现的技术,基本上就是现在AJAX最流行的应用方式了,不过这样也能叫AJAX吗?我宁可就叫它AJ,最多叫AJAH。
