中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > Java > J2EE
AJAX案例研究之详细剖析Gmail应用
作者:JiaJia 时间:2006-09-28 11:40 出处:ccidnet.com 责编:月夜寒箫
              摘要:AJAX案例研究之详细剖析Gmail应用

现在提起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应用吧。

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有