`

对Gmail中使用AJAX技术的研究

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

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

<html>
<head>
<meta content="text/html;
charset=UTF-8"
http-equiv="content-type">
<title>Gmailtitle>
<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,才能在标准视图中使用Gmail。然而,JavaScript似乎已被禁用,要么就是您的浏览器不支持JavaScript。要使用标准视图,请更改您的浏览器选项以启用 JavaScript,然后<a href="">重试<a>。<p>要使用 Gmail 的基本 HTML 视图(不需要 JavaScript),<a href="?ui=html&zy=n">请单击此处</a>。

<p>
</font>
</noscript>
<script>
</script>
</html>

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

    AJAX案例研究之Gmail

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

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

    ajax实现文件上传

    ps:Ajax技术基本上可以说是由google公司带起来的,但少Gmail中上传文件用的还是 IFrame,所以说使用IFrame来上传文件是最好的选择。 我在这里这里用的技术是jsp,其实asp,php等也是一样可以这么实现的

    AJAX开发简略(附源代码)

    AJAX开发简略... 1 一、AJAX定义...... 二、现状与需要解决的问题......三、为什么使用AJAX....四、谁在使用AJAX....如今,随着Gmail、Google-maps的应用和各种浏览器的支持,AJAX正逐渐吸引全世界的眼球。

    西班牙人写的类似GMAIL的FileUpload Ajax

    西班牙人写的类似GMAIL的FileUpload Ajax Example Code.aspx <cc1:FileUploaderAJAX ID="FileUploaderAJAX1" runat="server" MaxFiles="5" /> -----------------------------------------------------------------...

    ajax高级程序设计 源代码

    介绍了各种请求类型,给出了具有一定深度的有关如何以及何时在Web 站点或Web 应用程序中使用Ajax 的示例,以及各种数据传输格式及其优缺点;介绍了较为复杂的请求管理框架和Ajax 调试技术;讲述了两个完整的AjaxWeb ...

    javascript中ajax入门篇

    AJAX (Asynchronous JavaScript and XML, 异步 JavaScript 及 XML 技术) 是个新词,但内涵是两个存在已有一段时间的 JavaScript 功能。这两种功能以往一直被忽略,在 Gmail、Google suggest 及 Google Maps 出现后才...

    网页上仿Gmail拼写检查控件及 AJAX实现的TAB脚本控件

    网页上仿Gmail拼写检查控件及 AJAX实现的TAB脚本控件

    gmail无法使用解决方案

    gmail无法使用解决方案GoogleServicesFramework.apk GoogleCalendarSyncAdapter.apk GoogleContactsSyncAdapter.apk

    AJAX基础概念、核心技术与典型案例(内涵动态实例)

    1.本书1~16章所附代码的运行环境 ...程序描述:本章将仿照Google Suggest,使用Ajax技术实现动态获取搜索提示的功能。当输入搜索关键字时,自动向服务器发送请求,查询相关的关键字,并及时提示用户可输入的关键字。 ...

    AJAX学习源码下载

    AJAX技术已经是动态网页必不可少的技术了,最著名也最经典的应用就是Google主页搜索框的“搜索建议”(用户输入一个词条后,搜索框立刻出现很多相关词条提示),还有Google地图,Gmail,各种微博客,校内人人网,...

    自动登入Gmail邮箱—使用DotNet提供的库

    【图文教程】自动登入Gmail邮箱—使用DotNet提供的库 测试环境:WinXP SP3,VS2010,IE6.0 今天我们使用dotnet提供的库来实现gmail邮箱的自动登入。 这个想法来自于web自动化测试,即通过自己编程来使用IE COM和...

    Ajax工作原理深入理解

    而这也让微软感到无比的尴尬,因为早在97年,微软便已经发明了ajax中的关键技术,并且在99年IE5推出之时,它便开始支持XmlHttpRequest对象,并且微软之前已经开始在它的一些产品中应用ajax,比如说MSDN网站菜单中的...

    Ajax无刷新上传文件( jsp版本)

    ps:Ajax技术基本上可以说是由google公司带起来的,但少Gmail中上传文件用的还是 IFrame,所以说使用IFrame来上传文件是最好的选择。 我在这里这里用的技术是jsp,其实asp,php等也是一样可以这么实现的

    GMail Drive

    GMail Drive,是一个附加于微软Windows资源管理器的免费介壳 (Shell) 名称空间(Namespace) 扩展程序,使用它可以在工作站(个人计算机)上建立一个新的网络分享空间。你需要一个Gmail账户才能使用这个扩展程序。这个...

    Gmail邮箱检测工具Gmail Notifier Pro 5.3中文版.rar

    Gmail邮箱检测工具Gmail Notifier Pro是一款WINDOWS客户端程序,能够直接对Gmail邮箱进行操作,支持单帐号或多帐号同时登陆,运行后可以设定的时间自动检测邮箱中是否有新邮件,有新邮件时会语音提醒你。...

    make-your-own-gmail, 使用 Google JavaScript SDK AngularJS的Gmail副本示例.zip

    make-your-own-gmail, 使用 Google JavaScript SDK AngularJS的Gmail副本示例 制作你自己的Gmail.com可以定制的,独立的Gmail帐户接口。 这是一个可以编辑的脚手架,用于构建你自己的界面以与你的Gmail电子邮件帐户...

    Gmail客户端

    Gmail客户端,使用gmail的朋友可以直接下载使用。

    精通Ajax——基础概念、核心技术与典型案例之 书中源码

    书名:精通Ajax——基础概念、核心技术与典型案例 书中源码,如有什么问题,Email给我; 我的邮箱:qingyun0719@gmail.com

Global site tag (gtag.js) - Google Analytics