Chinaunix首页 | 论坛 | 博客
  • 博客访问: 14406561
  • 博文数量: 5645
  • 博客积分: 9880
  • 博客等级: 中将
  • 技术积分: 68081
  • 用 户 组: 普通用户
  • 注册时间: 2008-04-28 13:35
文章分类

全部博文(5645)

文章存档

2008年(5645)

我的朋友

分类:

2008-04-28 21:45:56

下载本文示例代码
天极软件专题专区精选     到天极软件“读编交流区”畅所欲言 Google专区 POPO专区 QQ专区 QQ挂机 了解Web2.0 Flash MX 视频教程 Photoshop视频教程 网页设计视频教程 照片处理数字暗房 PPT动画演示教程 Excel动画教程集 Word动画演示教程 Windows Vista专区 特洛伊木马专区 黑客知识教程专区 防火墙应用专区 注册表应用专区 Windows API开发专区 网络编程专区 VB数据库编程专区 图像处理与多媒体编程  现在提起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程序设计入门 天极软件专题专区精选     到天极软件“读编交流区”畅所欲言 Google专区 POPO专区 QQ专区 QQ挂机 了解Web2.0 Flash MX 视频教程 Photoshop视频教程 网页设计视频教程 照片处理数字暗房 PPT动画演示教程 Excel动画教程集 Word动画演示教程 Windows Vista专区 特洛伊木马专区 黑客知识教程专区 防火墙应用专区 注册表应用专区 Windows API开发专区 网络编程专区 VB数据库编程专区 图像处理与多媒体编程  现在提起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技术的研究对Gmail中使用AJAX技术的研究对Gmail中使用AJAX技术的研究对Gmail中使用AJAX技术的研究对Gmail中使用AJAX技术的研究对Gmail中使用AJAX技术的研究对Gmail中使用AJAX技术的研究对Gmail中使用AJAX技术的研究对Gmail中使用AJAX技术的研究对Gmail中使用AJAX技术的研究对Gmail中使用AJAX技术的研究对Gmail中使用AJAX技术的研究
阅读(229) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~