Ajax技术案例分析__AJAX案例研究之Gmail


======================================================
注:本文源代码点此下载
======================================================

现在提起ajax,大家都立刻会想起gmail、gogle map这几个经典的ajax应用gmail的优良表现我们都看过了,那么它的实现你研究过了吗?它怎么在几个不同的浏览器上可以一致的实现xml异步调用的呢?一起来看看吧

首先,登录gmail以后我们会先进入这个页面:

这是主框架网页兼浏览器检测页如果浏览器通过了检测(支持javascript、cookie和xml控件)则在页面上写一段框架代码要注意到的是google在这里耍了一个小花招,那个叫做main的框架页面里面看来没有多少东西,好东东都在那个叫js的框架里面呢

我们接着把这个js框架拉出来看看:整整1500多行的javascript代码!这个页面有240多k,几乎全都是javascript代码其实其中大部分都是老生常谈的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今天先到这,下回再过来分析另一个完全不同的ajax应用吧

推荐:ajax案例研究之google suggest


======================================================
在最后,我邀请大家参加新浪APP,就是新浪免费送大家的一个空间,支持PHP+MySql,免费二级域名,免费域名绑定 这个是我邀请的地址,您通过这个链接注册即为我的好友,并获赠云豆500个,价值5元哦!短网址是http://t.cn/SXOiLh我创建的小站每天访客已经达到2000+了,每天挂广告赚50+元哦,呵呵,饭钱不愁了,\(^o^)/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值