转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 站长学院 >> Web开发 >> 正文
AJAX案例研究之详细剖析Gmail应用         ★★★★

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

作者:闵涛 文章来源:闵涛的学习笔记 点击数:601 更新时间:2009/4/23 11:27:41

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

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

<html><head><meta
content="text/html;
charset=UTF-8" http-equiv="content-type">
<title>Gmail</title><link rel="alternate"
type="application/atom+xml"
title="Gmail Atom Feed"
href="feed/atom" /><script src="?view=page&name=browser&ver=c0d3d44c64799453">
</script></head><noscript>
<font face=arial>

这是主框架网页兼浏览器检测页。如果浏览器通过了检测(支持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应用吧。


[聊天工具]好消息:Gmail很快将向全球开放注册!  [聊天工具]聊天新方式:用Gmail信箱聊天
[聊天工具]Firefox小插件gspace把Gmail变FTP服务器  [聊天工具]Gmail即将支持用非gmail域名注册的账号
[聊天工具]Google将发布Gmail正式版 附广告服务__天极Yesky  [聊天工具]GMail Drive把Gmail变成你的免费硬盘__天极Yesky
[聊天工具]Gmail Hard Drive:Gmail邮箱变网络硬盘__天极Yes…  [常用软件]Google在华购买gmail.cn域名被拒绝
[常用软件]好消息:Gmail情人节全球皆可免费注册!  [常用软件]Gallina Gmail实现Blog体验报告
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Web开发  · 网页制作
    · 平面设计  · 网站运营
    · 网站推广  · 搜索优化
    · 建站心得  · 站长故事
    · 互联动态
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台