AJAX案例研究之详细剖析Gmail应用

2016-02-19 20:03 3 1 收藏

想要天天向上,就要懂得享受学习。图老师为大家推荐AJAX案例研究之详细剖析Gmail应用,精彩的内容需要你们用心的阅读。还在等什么快点来看看吧!

【 tulaoshi.com - Web开发 】

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

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

htmlheadmeta
content="text/html;
charset=UTF-8" http-equiv="content-type"
titleGmail/titlelink rel="alternate"
type="application/atom+xml"
title="Gmail Atom Feed"
href="feed/atom" /script src="?view=page&name=browser&ver=c0d3d44c64799453"
/script/headnoscript
font face=arial

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

我们接着把这个js框架拉出来看看:整整1500多行的javascript代码!这个页面有240多k,几乎全都是javascript代码。其实其中大部分都是老生常谈的js代码了,不过我们可以一窥google的编码风格:尽可能压缩信息量,变量名能用一个字母的绝不用两个,函数名一概都是两个字母的,函数内的会车是没有的,缩进也是没有的。

虽然代码没有特地加密,但是如此处理一番之后也就没什么可读性了。还好系统的关键字是不能缩水的,顺着xml控件的名字我们可以揪出来跟AJAX异步加载数据相关的几个关键函数:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

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:回调函数

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

基本上就这么多了,没有什么新鲜

的东西。发送http请求之后它又怎么处理返回的xml的呢?事实上他没有处理。他所处理的仅仅是最基本responseText,而cgi则直接生成js脚本到客户端回调(用eval运行),或者生成文本信息。这就是为什么gmail可以轻松跨域几个浏览器了。

作为最受推崇的一个AJAX应用,却几乎没有用到xml。像这样用xml控件来收发文本信息后在页面上展现的技术,基本上就是现在AJAX最流行的应用方式了,不过这样也能叫AJAX吗?我宁可就叫它AJ,最多叫AJAH。今天先到这,下回再过来分析另一个完全不同的AJAX应用吧。

来源:https://www.tulaoshi.com/n/20160219/1622606.html

延伸阅读
标签: Web开发
1.介绍 Ajax由于其良好的交互性,在去年很引人注目。Google Suggest 和 Google Maps [ref 1]就是一些Ajax早期的著名应用。现在,企业正在考虑他们如何也能利用Ajax,web开发者在学习它,安全专家在想如何使它变得安全,黑客们在思考如何入侵。所有能提高服务器吞吐量,能产生更多的动态页面传输,而且能为最终用户提供更加丰富的web应用的技...
标签: Web开发
红色的色感温暖,性格刚烈而外向,是一种对人刺激性很强的颜色。红色容易引起人的注意,也容易使人兴奋、激动、紧张、冲动、还是一种容易造成人视觉疲劳的颜色。 在众多颜色里,红色是最鲜明生动的、最热烈的颜色。因此红色也是代表热情的情感之色。鲜明红色极容易吸引人们的目光。 红色在不同的明度、纯度的状态(粉红、鲜红、...
标签: Web开发
在《Ajax开发精要》中,我构建了两个简单的综合范例。一个是支持增、删、改、模糊搜索的简单留言簿,另外一个是模拟MSN Space所提供的日志评论、固定链接、引用通告以及自定义列表管理的功能。 今天新增一个分页查询的案例。同样的,与之前的两个案例类似,分页查询的持久化数据依然来自xml文档,以方便网友的拷贝和部署。构建这个案例的方法与...
标签: Web开发
目前,在提供商业应用方面,IT行业对Web系统的依赖程度越来越高。Web浏览器虽然一直是向远程用户提供软件的一种理想的廉价方式,但它们并不能像桌面应用那样提供丰富的客户端功能。而通过AJAX(异步JavaScript及XML)则可以实现丰富的客户端交互能力和实时数据微量更新(micro-update),并且不需要使用任何一种私有的专用插件。 AJAX是一种使...
标签: Web开发
script type="text/javascript" language="javascript"     var http_request = false;     function makeRequest(url) {         http_request = false;         if (window.XMLHttpRequest) { // Mozilla, Safari,...   ...

经验教程

283

收藏

89
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部