weikent 发表于 2011-12-21 08:43

Ajax xmlhttprequest原理

<span class="Apple-style-span" style="font-family: verdana, sans-serif; font-size: 12px; ">&nbsp;Ajax xmlhttprequest原理(一)&nbsp;<a href="http://blog.csdn.net/liaolian9948/archive/2010/05/10/5575203.aspx" class="fav_csdnstylebykimi" title="收藏到我的网摘中,并分享给我的朋友" style="text-decoration: none; color: rgb(0, 0, 0); font: normal normal normal 12px/normal Tahoma, sans-serif; padding-top: 1px; padding-right: 25px; padding-bottom: 1px; padding-left: 10px; background-image: url(http://blog.csdn.net/images/share-add.gif); background-attachment: initial; background-origin: initial; background-clip: initial; background-color: initial; background-position: 0px 0px; background-repeat: no-repeat no-repeat; " target="_blank">收藏</a><div class="blogstory" style="float: left; width: 836px; font-size: 14px; line-height: 21px; "><div><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; "><strong>Ajax</strong></span><strong>原理及应用</strong></p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><strong></strong></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><strong><span lang="EN-US" style="line-height: 21px; ">1</span>、<span lang="EN-US" style="line-height: 21px; ">ajax</span>技术的背景<span lang="EN-US" style="line-height: 21px; "></span></strong></p><strong><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>不可否认,<span lang="EN-US" style="line-height: 21px; ">ajax</span>技术的流行得益于<span lang="EN-US" style="line-height: 21px; ">google</span>的大力推广,正是由于<span lang="EN-US" style="line-height: 21px; ">google earth</span>、<span lang="EN-US" style="line-height: 21px; ">google suggest</span>以及<span lang="EN-US" style="line-height: 21px; ">gmail</span>等对<span lang="EN-US" style="line-height: 21px; ">ajax</span>技术的广泛应用,催生了<span lang="EN-US" style="line-height: 21px; ">ajax</span>的流行。而这也让微软感到无比的尴尬,因为早在<span lang="EN-US" style="line-height: 21px; ">97</span>年,微软便已经发明了<span lang="EN-US" style="line-height: 21px; ">ajax</span>中的关键技术,并且在<span lang="EN-US" style="line-height: 21px; ">99</span>年<span lang="EN-US" style="line-height: 21px; ">IE5</span>推出之时,它便开始支持<span lang="EN-US" style="line-height: 21px; ">XmlHttpRequest</span>对象,并且微软之前已经开始在它的一些产品中应用<span lang="EN-US" style="line-height: 21px; ">ajax</span>,比如说<span lang="EN-US" style="line-height: 21px; ">MSDN</span>网站菜单中的一些应用。遗憾的是,不知道出于什么想法,当时微软发明了<span lang="EN-US" style="line-height: 21px; ">ajax</span>的核心技术之后,并没有看到它的潜力而加以发展和推广,而是将它搁置起来。对于这一点来说,我个人是觉得非常奇怪的,因为以微软的资源和它的战略眼光来说,应该不会看不到<span lang="EN-US" style="line-height: 21px; ">ajax</span>技术的前景,唯一的解释也许就是因为当时它的主要竞争对手<span lang="EN-US" style="line-height: 21px; ">Netscape</span>的消失反而使它变得麻痹和迟钝,毕竟巨人也有打盹的时候,比如<span lang="EN-US" style="line-height: 21px; ">IBM</span>曾经在对微软战略上的失误。正是这一次的失误,成就了它现在的竞争对手<span lang="EN-US" style="line-height: 21px; ">google</span>在<span lang="EN-US" style="line-height: 21px; ">ajax</span>方面的领先地位,而事实上<span lang="EN-US" style="line-height: 21px; ">google</span>目前在<span lang="EN-US" style="line-height: 21px; ">ajax</span>技术方面的领先是微软所无法达到的,这一点在后面我讲述<span lang="EN-US" style="line-height: 21px; ">ajax</span>缺陷的时候也会提到。现在微软也意识到了这个问题,因此它也开始在<span lang="EN-US" style="line-height: 21px; ">ajax</span>领域奋起直追,比如说推出它自己的<span lang="EN-US" style="line-height: 21px; ">ajax</span>框架<span lang="EN-US" style="line-height: 21px; ">atlas</span>,并且在<span lang="EN-US" style="line-height: 21px; ">.NET2.0</span>也提供了一个用来实现异步回调的接口,即<span lang="EN-US" style="line-height: 21px; ">ICallBack</span>接口。那么微软为什么对自己在<span lang="EN-US" style="line-height: 21px; ">ajax</span>方面的落后如此紧张呢?现在就让我们来分析一下<span lang="EN-US" style="line-height: 21px; ">ajax</span>技术后面隐藏的深刻意义。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">2</span>、<span lang="EN-US" style="line-height: 21px; ">ajax</span>技术的意义<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>我们在平时的开发中都多多少少的接触或者应用到了<span lang="EN-US" style="line-height: 21px; ">ajax</span>,谈到<span lang="EN-US" style="line-height: 21px; ">ajax</span>技术的意义,我们关注得最多的毫无疑问是提升用户的体验。但是,如果我们结合将来电脑和互联网的发展趋势,我们会发现<span lang="EN-US" style="line-height: 21px; ">ajax</span>技术在某些方面正好代表了这种趋势。为什么这样说呢?我们知道,自从电脑出现以来,一直是桌面软件占据着绝对主导的地位,但是互联网的出现和成功使这一切开始发生着微妙的变化。相当一部分的人都相信,迟早有一天,数据和电脑软件将会从桌面转移到互联网。也就是说,将来的电脑有可能抛弃笨重的硬盘,而直接从互联网来获取数据和服务,我记得我念大学的时候,有位教授给我们上课的时候,曾经设想过这样一种情景,也许在将来的电脑桌面上,没有任何多余的软件和程序,而仅仅只有一个<span lang="EN-US" style="line-height: 21px; ">IE</span>,虽然现在看起来我们距离这一天还很遥远,并且这其中还有很多的问题需要解决,但是我觉得这个并非梦想,而是迟早将实现的现实。那么,这其中的主要问题就是互联网的连接不稳定,谁也不愿意看着自己的电脑从服务器一点一滴的下载数据,那么,<span lang="EN-US" style="line-height: 21px; ">ajax</span>是不是解决了这个问题呢,说实话,与其说<span lang="EN-US" style="line-height: 21px; ">ajax</span>解决了这个问题,倒不如它只是掩盖了这个问题,它只是在服务器和客户端之间充当了一个缓冲器,让用户误以为服务没有中断。精确的说,<span lang="EN-US" style="line-height: 21px; ">ajax</span>并不能提高从服务器端下载数据的速度,而只是使这个等待不那么令人沮丧。但是正是这一点就足以产生巨大的影响和震动,它实际上也对桌面软件产生了巨大的冲击。这一点我用一个例子来说明,我们可以比较一下<span lang="EN-US" style="line-height: 21px; ">Outlook Express</span>和<span lang="EN-US" style="line-height: 21px; ">Gmail</span>,前者是典型的桌面软件,后者是<span lang="EN-US" style="line-height: 21px; ">ajax</span>所实现的<span lang="EN-US" style="line-height: 21px; ">B/S</span>模式,实际上后者目前已经在慢慢取代前者了,<span lang="EN-US" style="line-height: 21px; ">Gmail</span>在收发邮件的时候已经和<span lang="EN-US" style="line-height: 21px; ">Outlook Express</span>的功能几乎没有差别了,而且它不需要安装客户端程序。这就是为什么微软对<span lang="EN-US" style="line-height: 21px; ">ajax</span>所带来的冲击有着如此的恐惧心理,并且在它前不久所进行的调查之中,将<span lang="EN-US" style="line-height: 21px; ">google</span>看做他们未来十年内的主要竞争对手的主要原因之一。当然,这种变化也并不会将桌面软件全部淘汰,现有的浏览器还没有一个能像<span lang="EN-US" style="line-height: 21px; ">PhotoShop</span>等桌面程序那样处理复杂的图像。但是我们也不能忽视它带来的影响和冲击。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">3</span>、关于<span lang="EN-US" style="line-height: 21px; ">ajax</span>的名字<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp; ajax&nbsp;</span>的全称是<span lang="EN-US" style="line-height: 21px; ">Asynchronous JavaScript and XML</span>,其中,<span lang="EN-US" style="line-height: 21px; ">Asynchronous&nbsp;</span>是异步的意思,它有别于传统<span lang="EN-US" style="line-height: 21px; ">web</span>开发中采用的同步的方式。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">、关于同步和异步<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">异步传输是面向字符的传输,它的单位是字符;而同步传输是面向比特的传输,它的单位是桢,它传输的时候要求接受方和发送方的时钟是保持一致的。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">具体来说,异步传输是将比特分成小组来进行传送。一般每个小组是一个<span lang="EN-US" style="line-height: 21px; ">8</span>位字符,在每个小组的头部和尾部都有一个开始位和一个停止位,它在传送过程中接收方和发送方的时钟不要求一致,也就是说,发送方可以在任何时刻发送这些小组,而接收方并不知道它什么时候到达。一个最明显的例子就是计算机键盘和主机的通信,按下一个键的同时向主机发送一个<span lang="EN-US" style="line-height: 21px; ">8</span>比特位的<span lang="EN-US" style="line-height: 21px; ">ASCII</span>代码,键盘可以在任何时刻发送代码,这取决于用户的输入速度,内部的硬件必须能够在任何时刻接收一个键入的字符。这是一个典型的异步传输过程。异步传输存在一个潜在的问题,即接收方并不知道数据会在什么时候到达。在它检测到数据并做出响应之前,第一个比特已经过去了。这就像有人出乎意料地从后面走上来跟你说话,而你没来得及反应过来,漏掉了最前面的几个词。因此,每次异步传输的信息都以一个起始位开头,它通知接收方数据已经到达了,这就给了接收方响应、接收和缓存数据比特的时间;在传输结束时,一个停止位表示该次传输信息的终止。按照惯例,空闲(没有传送数据)的线路实际携带着一个代表二进制<span lang="EN-US" style="line-height: 21px; ">1</span>的信号。步传输的开始位使信号变成<span lang="EN-US" style="line-height: 21px; ">0</span>,其他的比特位使信号随传输的数据信息而变化。最后,停止位使信号重新变回<span lang="EN-US" style="line-height: 21px; ">1</span>,该信号一直保持到下一个开始位到达。例如在键盘上数字<span lang="EN-US" style="line-height: 21px; ">“1”</span>,按照<span lang="EN-US" style="line-height: 21px; ">8</span>比特位的扩展<span lang="EN-US" style="line-height: 21px; ">ASCII</span>编码,将发送<span lang="EN-US" style="line-height: 21px; ">“00110001”</span>,同时需要在<span lang="EN-US" style="line-height: 21px; ">8</span>比特位的前面加一个起始位,后面一个停止位。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">同步传输的比特分组要大得多。它不是独立地发送每个字符,每个字符都有自己的开始位和停止位,而是把它们组合起来一起发送。我们将这些组合称为数据帧,或简称为帧。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  数据帧的第一部分包含一组同步字符,它是一个独特的比特组合,类似于前面提到的起始位,用于通知接收方一个帧已经到达,但它同时还能确保接收方的采样速度和比特的到达速度保持一致,使收发双方进入同步。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  帧的最后一部分是一个帧结束标记。与同步字符一样,它也是一个独特的比特串,类似于前面提到的停止位,用于表示在下一帧开始之前没有别的即将到达的数据了。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  同步传输通常要比异步传输快速得多。接收方不必对每个字符进行开始和停止的操作。一旦检测到帧同步字符,它就在接下来的数据到达时接收它们。另外,同步传输的开销也比较少。例如,一个典型的帧可能有<span lang="EN-US" style="line-height: 21px; ">500</span>字节(即<span lang="EN-US" style="line-height: 21px; ">4000</span>比特)的数据,其中可能只包含<span lang="EN-US" style="line-height: 21px; ">100</span>比特的开销。这时,增加的比特位使传输的比特总数增加<span lang="EN-US" style="line-height: 21px; ">2.5%</span>,这与异步传输中<span lang="EN-US" style="line-height: 21px; ">25 %</span>的增值要小得多。随着数据帧中实际数据比特位的增加,开销比特所占的百分比将相应地减少。但是,数据比特位越长,缓存数据所需要的缓冲区也越大,这就限制了一个帧的大小。另外,帧越大,它占据传输媒体的连续时间也越长。在极端的情况下,这将导致其他用户等得太久。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">个小时,在这<span lang="EN-US" style="line-height: 21px; ">10</span>个小时内水没有完全断,只是流量比原来小了很多,在<span lang="EN-US" style="line-height: 21px; ">10</span>个小时后恢复正常流量,那么,如果是你你会选择哪种方式呢?显然是后者。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">4</span>、<span lang="EN-US" style="line-height: 21px; ">ajax</span>所包含的技术<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;</span>大家都知道<span lang="EN-US" style="line-height: 21px; ">ajax</span>并非一种新的技术,而是几种原有技术的结合体。它由下列技术组合而成。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp; 1.</span>使用<span lang="EN-US" style="line-height: 21px; ">CSS</span>和<span lang="EN-US" style="line-height: 21px; ">XHTML</span>来表示。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp; 2.&nbsp;</span>使用<span lang="EN-US" style="line-height: 21px; ">DOM</span>模型来交互和动态显示。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp; 3.</span>使用<span lang="EN-US" style="line-height: 21px; ">XMLHttpRequest</span>来和服务器进行异步通信。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp; 4.</span>使用<span lang="EN-US" style="line-height: 21px; ">javascript</span>来绑定和调用。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">在上面几中技术中,除了<span lang="EN-US" style="line-height: 21px; ">XmlHttpRequest</span>对象以外,其它所有的技术都是基于<span lang="EN-US" style="line-height: 21px; ">web</span>标准并且已经得到了广泛使用的,<span lang="EN-US" style="line-height: 21px; ">XMLHttpRequest</span>虽然目前还没有被<span lang="EN-US" style="line-height: 21px; ">W3C</span>所采纳,但是它已经是一个事实的标准,因为目前几乎所有的主流浏览器都支持它。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">5</span>、<span lang="EN-US" style="line-height: 21px; ">ajax</span>原理和<span lang="EN-US" style="line-height: 21px; ">XmlHttpRequest</span>对象<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">Ajax</span>的原理简单来说通过<span lang="EN-US" style="line-height: 21px; ">XmlHttpRequest</span>对象来向服务器发异步请求,从服务器获得数据,然后用<span lang="EN-US" style="line-height: 21px; ">javascript</span>来操作<span lang="EN-US" style="line-height: 21px; ">DOM</span>而更新页面。这其中最关键的一步就是从服务器获得请求数据。要清楚这个过程和原理,我们必须对<span lang="EN-US" style="line-height: 21px; ">&nbsp;XMLHttpRequest</span>有所了解。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">XMLHttpRequest</span>是<span lang="EN-US" style="line-height: 21px; ">ajax</span>的核心机制,它是在<span lang="EN-US" style="line-height: 21px; ">IE5</span>中首先引入的,是一种支持异步请求的技术。简单的说,也就是<span lang="EN-US" style="line-height: 21px; ">javascript</span>可以及时向服务器提出请求和处理响应,而不阻塞用户。达到无刷新的效果。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">所以我们先从<span lang="EN-US" style="line-height: 21px; ">XMLHttpRequest</span>讲起,来看看它的工作原理。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">首先,我们先来看看<span lang="EN-US" style="line-height: 21px; ">XMLHttpRequest</span>这个对象的属性。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">它的属性有:<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">onreadystatechange&nbsp;</span>每次状态改变所触发事件的事件处理程序。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">responseText&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>从服务器进程返回数据的字符串形式。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">respon***ML&nbsp;&nbsp;&nbsp;</span>从服务器进程返回的<span lang="EN-US" style="line-height: 21px; ">DOM</span>兼容的文档数据对象。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">status&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>从服务器返回的数字代码,比如常见的<span lang="EN-US" style="line-height: 21px; ">404</span>(未找到)和<span lang="EN-US" style="line-height: 21px; ">200</span>(已就绪)<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">status Text&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>伴随状态码的字符串信息<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">readyState&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span>对象状态值<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">0 (</span>未初始化<span lang="EN-US" style="line-height: 21px; ">)&nbsp;</span>对象已建立,但是尚未初始化(尚未调用<span lang="EN-US" style="line-height: 21px; ">open</span>方法)<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">1 (</span>初始化<span lang="EN-US" style="line-height: 21px; ">)&nbsp;</span>对象已建立,尚未调用<span lang="EN-US" style="line-height: 21px; ">send</span>方法<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">2 (</span>发送数据<span lang="EN-US" style="line-height: 21px; ">) send</span>方法已调用,但是当前的状态及<span lang="EN-US" style="line-height: 21px; ">http</span>头未知<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">3 (</span>数据传送中<span lang="EN-US" style="line-height: 21px; ">)&nbsp;</span>已接收部分数据,因为响应及<span lang="EN-US" style="line-height: 21px; ">http</span>头不全,这时通过<span lang="EN-US" style="line-height: 21px; ">responseBody</span>和<span lang="EN-US" style="line-height: 21px; ">responseText</span>获取部分数据会出现错误,<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">4 (</span>完成<span lang="EN-US" style="line-height: 21px; ">)&nbsp;</span>数据接收完毕<span lang="EN-US" style="line-height: 21px; ">,</span>此时可以通过通过<span lang="EN-US" style="line-height: 21px; ">respon***ml</span>和<span lang="EN-US" style="line-height: 21px; ">responseText</span>获取完整的回应数据<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">但是,由于各浏览器之间存在差异,所以创建一个<span lang="EN-US" style="line-height: 21px; ">XMLHttpRequest</span>对象可能需要不同的方法。这个差异主要体现在<span lang="EN-US" style="line-height: 21px; ">IE</span>和其它浏览器之间。下面是一个比较标准的创建<span lang="EN-US" style="line-height: 21px; ">XMLHttpRequest</span>对象的方法。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">function</span><span lang="EN-US" style="line-height: 21px; ">&nbsp;CreateXmlHttp()</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp; {</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp; //</span>非<span lang="EN-US" style="line-height: 21px; ">IE</span>浏览器创建<span lang="EN-US" style="line-height: 21px; ">XmlHttpRequest</span>对象<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp; if(window.XmlHttpRequest)</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp; {</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp; xmlhttp=new XmlHttpRequest();</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp; }</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp; //IE</span>浏览器创建<span lang="EN-US" style="line-height: 21px; ">XmlHttpRequest</span>对象<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp; if(window.ActiveXObject)</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp; {</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp; try</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp; {</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp; xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");&nbsp;&nbsp;&nbsp;&nbsp;</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp; }</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp; catch(e)</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp; {</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp; try{</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp; xmlhttp=new ActiveXObject("msxml2.XMLHTTP");</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp; }</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp; catch(ex){}</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp; }</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp; }</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp; }</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">function</span><span lang="EN-US" style="line-height: 21px; ">&nbsp;TestAjax()</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp; {</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp; var data=document.getElementById("username").value;&nbsp;&nbsp;</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; CreateXmlHttp();</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; if(!xmlhttp)</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; {</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; alert("</span>创建<span lang="EN-US" style="line-height: 21px; ">xmlhttp</span>对象异常!<span lang="EN-US" style="line-height: 21px; ">"</span><span lang="EN-US" style="line-height: 21px; ">);</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; return false;</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; xmlhttp.open("POST",url,false);</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; xmlhttp.onreadystatechange=function()</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; {&nbsp;&nbsp;</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; if(xmlhttp.readyState==4)</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; {</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; document.getElementById("user1").innerHTML="</span>数据正在加载<span lang="EN-US" style="line-height: 21px; ">..."</span><span lang="EN-US" style="line-height: 21px; ">;</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; if(xmlhttp.status==200)</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; {</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; document.write(xmlhttp.responseText);</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; xmlhttp.send();</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp; }</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">如上所示,函数首先检查<span lang="EN-US" style="line-height: 21px; ">XMLHttpRequest</span>的整体状态并且保证它已经完成(<span lang="EN-US" style="line-height: 21px; ">readyStatus=4</span>),即数据已经发送完毕。然后根据服务器的设定询问请求状态,如果一切已经就绪(<span lang="EN-US" style="line-height: 21px; ">status=200</span>),那么就执行下面需要的操作。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">对于<span lang="EN-US" style="line-height: 21px; ">XmlHttpRequest</span>的两个方法,<span lang="EN-US" style="line-height: 21px; ">open</span>和<span lang="EN-US" style="line-height: 21px; ">send</span>,其中<span lang="EN-US" style="line-height: 21px; ">open</span>方法指定了:<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">a</span>、向服务器提交数据的类型,即<span lang="EN-US" style="line-height: 21px; ">post</span>还是<span lang="EN-US" style="line-height: 21px; ">get</span>。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">b</span>、请求的<span lang="EN-US" style="line-height: 21px; ">url</span>地址和传递的参数。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">c</span>、传输方式,<span lang="EN-US" style="line-height: 21px; ">false</span>为同步,<span lang="EN-US" style="line-height: 21px; ">true</span>为异步。默认为<span lang="EN-US" style="line-height: 21px; ">true</span>。如果是异步通信方式<span lang="EN-US" style="line-height: 21px; ">(true)</span>,客户机就不等待服务器的响应;如果是同步方式<span lang="EN-US" style="line-height: 21px; ">(false)</span>,客户机就要等到服务器返回消息后才去执行其他操作。我们需要根据实际需要来指定同步方式,在某些页面中,可能会发出多个请求,甚至是有组织有计划有队形大规模的高强度的<span lang="EN-US" style="line-height: 21px; ">request</span>,而后一个是会覆盖前一个的,这个时候当然要指定同步方式。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp; Send</span>方法用来发送请求。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">知道了<span lang="EN-US" style="line-height: 21px; ">XMLHttpRequest</span>的工作流程,我们可以看出,<span lang="EN-US" style="line-height: 21px; ">XMLHttpRequest</span>是完全用来向服务器发出一个请求的,它的作用也局限于此,但它的作用是整个<span lang="EN-US" style="line-height: 21px; ">ajax</span>实现的关键,因为<span lang="EN-US" style="line-height: 21px; ">ajax</span>无非是两个过程,发出请求和响应请求。并且它完全是一种客户端的技术。而<span lang="EN-US" style="line-height: 21px; ">XMLHttpRequest</span>正是处理了服务器端和客户端通信的问题所以才会如此的重要。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">现在,我们对<span lang="EN-US" style="line-height: 21px; ">ajax</span>的原理大概可以有一个了解了。我们可以把服务器端看成一个数据接口,它返回的是一个纯文本流,当然,这个文本流可以是<span lang="EN-US" style="line-height: 21px; ">XML</span>格式,可以是<span lang="EN-US" style="line-height: 21px; ">Html</span>,可以是<span lang="EN-US" style="line-height: 21px; ">Javascript</span>代码,也可以只是一个字符串。这时候,<span lang="EN-US" style="line-height: 21px; ">XMLHttpRequest</span>向服务器端请求这个页面,服务器端将文本的结果写入页面,这和普通的<span lang="EN-US" style="line-height: 21px; ">web</span>开发流程是一样的,不同的是,客户端在异步获取这个结果后,不是直接显示在页面,而是先由<span lang="EN-US" style="line-height: 21px; ">javascript</span>来处理,然后再显示在页面。至于现在流行的很多<span lang="EN-US" style="line-height: 21px; ">ajax</span>控件,比如<span lang="EN-US" style="line-height: 21px; ">magicajax</span>等,可以返回<span lang="EN-US" style="line-height: 21px; ">DataSet</span>等其它数据类型,只是将这个过程封装了的结果,本质上他们并没有什么太大的区别。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">6</span>、<span lang="EN-US" style="line-height: 21px; ">ajax</span>的优点<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp; Ajax</span>的给我们带来的好处大家基本上都深有体会,在这里我只简单的讲几点:<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp; 1</span>、最大的一点是页面无刷新,在页面内与服务器通信,给用户的体验非常好。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "> <span lang="EN-US" style="line-height: 21px; ">&nbsp;2</span>、使用异步方式与服务器通信,不需要打断用户的操作,具有更加迅速的响应能力。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "> <span lang="EN-US" style="line-height: 21px; ">&nbsp;3</span>、可以把以前一些服务器负担的工作转嫁到客户端,利用客户端闲置的能力来处理,减轻服务器和带宽的负担,节约空间和宽带租用成本。并且减轻服务器的负担,<span lang="EN-US" style="line-height: 21px; ">ajax</span>的原则是<span lang="EN-US" style="line-height: 21px; ">“</span>按需取数据<span lang="EN-US" style="line-height: 21px; ">”</span>,可以最大程度的减少冗余请求,和响应对服务器造成的负担。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">4</span>、基于标准化的并被广泛支持的技术,不需要下载插件或者小程序。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">7</span>、<span lang="EN-US" style="line-height: 21px; ">ajax</span>的缺点<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">下面我着重讲一讲<span lang="EN-US" style="line-height: 21px; ">ajax</span>的缺陷,因为平时我们大多注意的都是<span lang="EN-US" style="line-height: 21px; ">ajax</span>给我们所带来的好处诸如用户体验的提升。而对<span lang="EN-US" style="line-height: 21px; ">ajax</span>所带来的缺陷有所忽视。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">下面所阐述的<span lang="EN-US" style="line-height: 21px; ">ajax</span>的缺陷都是它先天所产生的。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp; 1</span>、<span lang="EN-US" style="line-height: 21px; ">ajax</span>干掉了<span lang="EN-US" style="line-height: 21px; ">back</span>按钮,即对浏览器后退机制的破坏。后退按钮是一个标准的<span lang="EN-US" style="line-height: 21px; ">web</span>站点的重要功能,但是它没法和<span lang="EN-US" style="line-height: 21px; ">js</span>进行很好的合作。这是<span lang="EN-US" style="line-height: 21px; ">ajax</span>所带来的一个比较严重的问题,因为用户往往是希望能够通过后退来取消前一次操作的。那么对于这个问题有没有办法?答案是肯定的,用过<span lang="EN-US" style="line-height: 21px; ">Gmail</span>的知道,<span lang="EN-US" style="line-height: 21px; ">Gmail</span>下面采用的<span lang="EN-US" style="line-height: 21px; ">ajax</span>技术解决了这个问题,在<span lang="EN-US" style="line-height: 21px; ">Gmail</span>下面是可以后退的,但是,它也并不能改变<span lang="EN-US" style="line-height: 21px; ">ajax</span>的机制,它只是采用的一个比较笨但是有效的办法,即用户单击后退按钮访问历史记录时,通过创建或使用一个隐藏的<span lang="EN-US" style="line-height: 21px; ">IFRAME</span>来重现页面上的变更。(例如,当用户在<span lang="EN-US" style="line-height: 21px; ">Google Maps</span>中单击后退时,它在一个隐藏的<span lang="EN-US" style="line-height: 21px; ">IFRAME</span>中进行搜索,然后将搜索结果反映到<span lang="EN-US" style="line-height: 21px; ">Ajax</span>元素上,以便将应用程序状态恢复到当时的状态。)<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">但是,虽然说这个问题是可以解决的,但是它所带来的开发成本是非常高的,和<span lang="EN-US" style="line-height: 21px; ">ajax</span>框架所要求的快速开发是相背离的。这是<span lang="EN-US" style="line-height: 21px; ">ajax</span>所带来的一个非常严重的问题。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">2</span>、安全问题<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">技术同时也对<span lang="EN-US" style="line-height: 21px; ">IT</span>企业带来了新的安全威胁,<span lang="EN-US" style="line-height: 21px; ">ajax</span>技术就如同对企业数据建立了一个直接通道。这使得开发者在不经意间会暴露比以前更多的数据和服务器逻辑。<span lang="EN-US" style="line-height: 21px; ">ajax</span>的逻辑可以对客户端的安全扫描技术隐藏起来,允许黑客从远端服务器上建立新的攻击。还有<span lang="EN-US" style="line-height: 21px; ">ajax</span>也难以避免一些已知的安全弱点,诸如跨站点脚步攻击、<span lang="EN-US" style="line-height: 21px; ">SQL</span>注入攻击和基于<span lang="EN-US" style="line-height: 21px; ">credentials</span>的安全漏洞等。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">3</span>、对搜索引擎的支持比较弱。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">4</span>、破坏了程序的异常机制。至少从目前看来,像<span lang="EN-US" style="line-height: 21px; ">ajax.dll</span>,<span lang="EN-US" style="line-height: 21px; ">ajaxpro.dll</span>这些<span lang="EN-US" style="line-height: 21px; ">ajax</span>框架是会破坏程序的异常机制的。关于这个问题,我曾经在开发过程中遇到过,但是查了一下网上几乎没有相关的介绍。后来我自己做了一次试验,分别采用<span lang="EN-US" style="line-height: 21px; ">ajax</span>和传统的<span lang="EN-US" style="line-height: 21px; ">form</span>提交的模式来删除一条数据<span lang="EN-US" style="line-height: 21px; ">……</span>给我们的调试带来了很大的困难。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">5</span>、另外,像其他方面的一些问题,比如说违背了<span lang="EN-US" style="line-height: 21px; ">url</span>和资源定位的初衷。例如,我给你一个<span lang="EN-US" style="line-height: 21px; ">url</span>地址,如果采用了<span lang="EN-US" style="line-height: 21px; ">ajax</span>技术,也许你在该<span lang="EN-US" style="line-height: 21px; ">url</span>地址下面看到的和我在这个<span lang="EN-US" style="line-height: 21px; ">url</span>地址下看到的内容是不同的。这个和资源定位的初衷是相背离的。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">6</span>、一些手持设备(如手机、<span lang="EN-US" style="line-height: 21px; ">PDA</span>等)现在还不能很好的支持<span lang="EN-US" style="line-height: 21px; ">ajax</span>,比如说我们在手机的浏览器上打开采用<span lang="EN-US" style="line-height: 21px; ">ajax</span>技术的网站时,它目前是不支持的,当然,这个问题和我们没太多关系。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">8</span>、<span lang="EN-US" style="line-height: 21px; ">ajax</span>的几种框架<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">目前我们采用的比较多的<span lang="EN-US" style="line-height: 21px; ">ajax</span>框架主要有<span lang="EN-US" style="line-height: 21px; ">ajax.dll,ajaxpro.dll,magicajax.dll&nbsp;</span>以及微软的<span lang="EN-US" style="line-height: 21px; ">atlas</span>框架。<span lang="EN-US" style="line-height: 21px; ">Ajax.dll</span>和<span lang="EN-US" style="line-height: 21px; ">Ajaxpro.dll</span>这两个框架差别不大,而<span lang="EN-US" style="line-height: 21px; ">magicajax.dll</span>只是封装得更厉害一些,比如说它可以直接返回<span lang="EN-US" style="line-height: 21px; ">DataSet</span>数据集,前面我们已经说过,<span lang="EN-US" style="line-height: 21px; ">ajax</span>返回的都是字符串,<span lang="EN-US" style="line-height: 21px; ">magicajax</span>只是对它进行了封装而已。但是它的这个特点可以给我们带来很大的方便,比如说我们的页面有一个列表,而列表的数据是不断变化的,那么我们可以采用<span lang="EN-US" style="line-height: 21px; ">magicajax</span>来处理,操作很简单,添加<span lang="EN-US" style="line-height: 21px; ">magicajax</span>之后,将要更新的列表控件放在<span lang="EN-US" style="line-height: 21px; ">magicajax</span>的控件之内,然后在<span lang="EN-US" style="line-height: 21px; ">pageload</span>里面定义更新间隔的时间就<span lang="EN-US" style="line-height: 21px; ">ok</span>了,<span lang="EN-US" style="line-height: 21px; ">atlas</span>的原理和<span lang="EN-US" style="line-height: 21px; ">magicajax</span>差不多。但是,需要注意的一个问题是,这几种框架都只支持<span lang="EN-US" style="line-height: 21px; ">IE</span>,没有进行浏览器兼容方面的处理,用反编译工具察看他们的代码就可以知道。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">除了这几种框架之外,我们平时用到的比较多的方式是自己创建<span lang="EN-US" style="line-height: 21px; ">xmlHttpRequest</span>对象,这种方式和前面的几种框架相比更具有灵活性。另外,在这里还提一下<span lang="EN-US" style="line-height: 21px; ">aspnet2.0</span>自带的异步回调接口,它和<span lang="EN-US" style="line-height: 21px; ">ajax</span>一样也可以实现局部的无刷新,但它的实现实际上也是基于<span lang="EN-US" style="line-height: 21px; ">xmlhttprequest</span>对象的,另外也是只支持<span lang="EN-US" style="line-height: 21px; ">IE</span>,当然这是微软的一个竞争策略。<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">9.ajax</span>应用举例<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">以上内容是转载高人写的资料,下面我将我在项目中实际应用给出个例子,这个例子是这样的:我参与的一个项目的值班安排模块里,选择值班人时,弹出的是个联系人树型<span lang="EN-US" style="line-height: 21px; ">TreeView</span>结构图,点开哪个部门,然后部门下的联系人就展开了,原先是这样的,选择好某些联系人后,哪天白天或晚上的值班人就是这样的格式<span lang="EN-US" style="line-height: 21px; ">”</span>小<span lang="EN-US" style="line-height: 21px; ">A</span>,小<span lang="EN-US" style="line-height: 21px; ">B”</span>,但是现在要求这样的格式<span lang="EN-US" style="line-height: 21px; ">”</span>小<span lang="EN-US" style="line-height: 21px; ">A(</span>部门一<span lang="EN-US" style="line-height: 21px; ">)</span>,小<span lang="EN-US" style="line-height: 21px; ">B</span>(部门二)<span lang="EN-US" style="line-height: 21px; ">”</span>这里假设小<span lang="EN-US" style="line-height: 21px; ">A</span>属于部门一,小<span lang="EN-US" style="line-height: 21px; ">B</span>属于部门二。由于选择联系人是纯前台<span lang="EN-US" style="line-height: 21px; ">javascript</span>的操作的,这里要通过联系人<span lang="EN-US" style="line-height: 21px; ">userlist</span>表中的部门<span lang="EN-US" style="line-height: 21px; ">id</span>,来取得部门的名称,也就是通过前台取后台的数据,这个在系列五里我也阐述过,下面给出代码:<span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">var param&nbsp; = "date=&lt;%=stryear%&gt;/&lt;%=strmonth%&gt;/" + x</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; +"&amp;Type=" + type</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; +"&amp;Other=" + eval("formData.RBOTHER"+x+".value")</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; +"&amp;ZBRY=" + eval("formData.RBZBRY"+x+".value")</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; +"&amp;ZBRYID=" + eval("formData.RBZBRYID"+x+".value")</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; +"&amp;Demo=" + eval("formData.RBDEMO"+x+".value")</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; +"&amp;id=" + eval("formData.RBZBID"+x+".value");//</span><span style="line-height: 21px; ">传递的参数<span lang="EN-US" style="line-height: 21px; "></span></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; var retVal = window.showModalDialog( "chooseUsers.asp?"+param,this, "dialogWidth=280px; dialogHeight=500px; help=no; status=no; scroll=no; resizable=yes; ");</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">//</span><span style="line-height: 21px; ">弹出对话框取得联系人<span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</span></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">//ajax</span><span style="line-height: 21px; ">调用服务器端方法取到部门名称<span lang="EN-US" style="line-height: 21px; "></span></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; "></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">if(retVal ['userIds']!=""&amp;&amp; retVal ['userIds']!=null)//</span><span style="line-height: 21px; ">联系人<span lang="EN-US" style="line-height: 21px; ">id</span>集合格式<span lang="EN-US" style="line-height: 21px; ">1</span>,<span lang="EN-US" style="line-height: 21px; ">2</span>,<span lang="EN-US" style="line-height: 21px; ">3</span>,<span lang="EN-US" style="line-height: 21px; ">4&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;</span></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">{</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp; var PostUrl=" ../../../Application/CallBoard/GetDepartMentByUid.aspx?userIDs="+objRetVal['userIds']+"";//</span><span style="line-height: 21px; ">后台处理页面<span lang="EN-US" style="line-height: 21px; ">url</span></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");//</span><span style="line-height: 21px; ">新建一个<span lang="EN-US" style="line-height: 21px; ">xmlhttprequest</span>对象<span lang="EN-US" style="line-height: 21px; "></span></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; xmlHttp.open("POST", PostUrl, false);</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; xmlHttp.send("");</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;var builder= xmlHttp.responseText; //</span><span style="line-height: 21px; ">将值传递回来<span lang="EN-US" style="line-height: 21px; ">,</span>拼成了新格式<span lang="EN-US" style="line-height: 21px; "></span></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; &nbsp;eval("formData.RBZBRY"+x+".value = '" +builder+"'");// formData.RBZBRY</span><span style="line-height: 21px; ">为一文本控件<span lang="EN-US" style="line-height: 21px; ">,</span>将显示值班人员新格式<span lang="EN-US" style="line-height: 21px; "></span></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span lang="EN-US" style="line-height: 21px; ">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }</span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span style="line-height: 21px; ">整个过程页面是无所新的,<span lang="EN-US" style="line-height: 21px; ">ajax</span>异步调用让用户有了很好用户体验。好就写这么多吧,今后将深入探讨下</span><span style="line-height: 19px; font-size: small; "><span lang="EN-US" style="line-height: 19px; "><span style="line-height: 19px; font-family: 'Times New Roman'; ">XmlHttpRequest</span></span><span style="line-height: 19px; ">对象。这个才是核心。</span></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">&nbsp;</p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span style="line-height: 19px; font-size: small; "><span style="line-height: 19px; ">----------------------------------------------------------------------</span></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span style="line-height: 19px; font-size: small; "><span style="line-height: 19px; ">XMLHTTPREQUEST</span></span></p><p class="MsoNormal" align="left" style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "><span style="line-height: 19px; font-size: small; "><span style="line-height: 19px; "><br></span></span></p></strong><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; "></p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">一、 简介</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  AJAX,一个异步JavaScript和XML的缩略词,是最近出来的技术词语。异步意味着你可以经由超文本传输协议(HTTP)向一个服务器发出请求并且在等待该响应时继续处理另外的数据。这就意味着,例如,你可以调用一个服务器端脚本来从一个数据库中以XML方式检索数据,把数据发送到存储在一个数据库的服务器脚本,或者简单地装载一个XML文件以填充你的Web站点而不需刷新该页面。然而,在这项新技术提供巨大能力的同时,它也引起了在"Back"按钮问题上的很多争论。本文将帮助你确定在真实世界中何时使用AJAX是最佳选择。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  首先,我假定你对缩略词JavaScript和XML部分有一个基本了解。尽管你能通过AJAX请求任何类型的文本文件,但是我在此主要集中讨论XML。我将解释怎样在真实世界中使用AJAX以及怎样在一个工程中评估它的价值。在你读完本文后,你将会明白什么是AJAX,在什么情况下,为什么以及怎样使用这项技术。你将要学习,在保持给用户提供直观体验的同时怎样创建对象,发出请求以及定制响应。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  我已创建了一个适合于本文的示例工程(你可以下载源代码)。这个示例实现了一个简单的请求-它装载一个包含页面内容的XML文件并且分析数据以把它显示在一个HTML页面中。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  二、 常规属性和方法</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  表1和2提供了一个属性和方法的概述-它们为Windows Internet Explorer 5,Mozilla,Netscape 7,Safari 1.2,和Opera等浏览器所支持。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  表1属性</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  属性 描述</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  onreadystatechange 当请求对象变化时该事件处理器激活。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  readyState 返回指示对象的当前状态的值。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  responseText 来自服务器的响应串的版本。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  respon***ML 来自服务器的响应的DOM兼容的文档对象。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  status 来自服务器的响应的状态码。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  statusText 以一个字符串形式返回的状态消息。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  表2方法</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  方法 描述</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  Abort() 取消当前HTTP请求。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  getAllResponseHeaders() 检索所有的HTTP头值。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  getResponseHeader("headerLabel") 从响应体中检索一个HTTP头部的值。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  open("method","URL"[,asyncFlag[,"userName"[,"password"]]]) 初始化一个MSXML2.XMLHTTP请求,并从该请求指定方法,URL和认证信息。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  send(content) 发送一个HTTP请求到服务器并接收响应。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  setRequestHeader("label", "value") 指定一个HTTP头的名字。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  三、 从哪里开始</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  首先,你需要创建XML文件-后面我们对之进行请求并作为页面内容进行分析。你正在请求的文件必须与目标工程驻留在相同的服务器上。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  下一步,创建发出请求的HTML文件。当页面通过使用页面主体中的onload方法进行加载时,该请求发生。接着,该文件需要一个有ID的div标签,这样当我们准备好要显示内容时就可以对之进行定位。当你做完所有这些,你的页面的主体看上去如下:</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  <body onload="makeRequest('xml/content.xml'); ">&nbsp;<br>  <div id="copy"></div><br>  </body></p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  四、 创建请求对象</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  为了创建请求对象,你必须检查是否浏览器使用XMLHttpRequest或ActiveXObject。这两个对象之间的主要区别在于使用它们的浏览器。Windows IE 5 及以上版本使用ActiveX对象; 而Mozilla,Netscape 7,Opera和Safari 1.2及以上版本使用XMLHttpRequest对象。另外一个区别是你创建对象的方式:Opera,Mozilla,Netscape和Safari允许你简单地调用该对象的构造器,但是Windows IE需要把对象的名字传递到ActiveX构造器中。下面是怎样创建代码来决定要使用哪个对象和怎样创建它的示例:</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  if(window.XMLHttpRequest)&nbsp;<br>  { request = new XMLHttpRequest(); }<br>  else if(window.ActiveXObject)<br>  { request = new ActiveXObject("MSXML2.XMLHTTP"); }</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  五、 发出请求</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  现在既然你已经创建了你的请求对象,那么你已经为向服务器发出请求作了准备。创建一个到事件处理器的参考以听取onreadystatechange事件。然后,该事件处理器方法将在状态发生变化时作出响应。一旦我们完成请求,我们就开始创建这个方法。打开连接以GET或POST一个定制的URL-在此是一个content.xml,并且设置一个布尔定义-是否你想要进行异步调用。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  现在到了发出请求的时间了。在这个示例中,我使用了null,因为我们使用的是GET; 为了使用POST,你需要使用下面这个方法发出一个查询串:</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  request.onreadystatechange = onResponse;&nbsp;<br>  request.open("GET". url, true);&nbsp;<br>  request.send(null);</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  六、 定制加载和错误处理消息</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  你为onreadystatechange方法创建的事件处理器正是集中进行加载和处理错误的场所。现在到了考虑用户并针对他们与之交互的内容的状态提供反馈的时候了。在这个实例中,我针对所有的装载状态代码提供反馈,并且也对最经常发生的错误处理状态代码提供一些基本的反馈。为了显示请求对象的当前状态,readyState属性包括显示在下表中的一些值。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  值 描述</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  0 未初始化,对象没有用数据进行初始化。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  1 装载中,对象正在装载它的数据。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  2 装载结束,对象完成了它的数据的装载。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  3 可交互,用户能与对象交互了,尽管它还没有装载结束。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  4 完成,对象已经完全被初始化。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  W3C中有很长的一串有关HTTP状态代码的定义。我选择了两个状态代码:</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  ?200:请求成功了。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  ?404:服务器没有找到与所请求的文件相匹配的任何东西。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  最后,我检查任何另外的状况代码-它们将生成一个错误并提供一个一般错误信息。下面是一个代码示例-你可以用之来处理这些情况。注意,我在定位我们前面在HTML文件的主体中创建的div ID并且对它应用装载和/或错误信息-通过innerHTML方法-这个方法用于设置在div对象的开始和结束标签之间的HTML:</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  if(obj.readyState == 0)&nbsp;<br>  { document.getElementById('copy').innerHTML = "Sending Request..."; }<br>  if(obj.readyState == 1)<br>  { document.getElementById('copy').innerHTML = "Loading Response..."; }<br>  if(obj.readyState == 2)<br>  { document.getElementById('copy').innerHTML = "Response Loaded..."; }<br>  if(obj.readyState == 3)<br>  { document.getElementById('copy').innerHTML = "Response Ready..."; }<br>  if(obj.readyState == 4){<br>  if(obj.status == 200){ return true; }<br>  else if(obj.status == 404)<br>  {<br>  // 添加一个定制消息或把用户重定向到另外一个页面<br>  document.getElementById('copy').innerHTML = "File not found";&nbsp;<br>  }<br>  else<br>  {document.getElementById('copy').innerHTML = "There was a problem retrieving the XML."; }<br>  }</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  当状况代码为200时,这意味着请求成功。下面开始进行响应了。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  七、分析响应</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  当你准备好分析来自请求对象的响应时,真正的工作开始了。现在你可以用你请求的数据开始工作。仅为测试目的,在开发期间,可以使用responseText和respon***ML属性来显示来自响应的原始数据。为了存取XML响应中的结点,首先使用你创建的请求对象,定位到respon***ML属性以检索(你可能已经猜测出来)来自响应的XML。定位到documentElement-它检索一个到XML响应的根结点的参考。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  var response = request.respon***ML.documentElement;</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  现在既然你有了到响应的根结点的参考,那么你可以使用getElementsByTagName()以结点名字来检索childNodes。下面一行用一个头部的nodeName来定位一个childNode:</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  response.getElementsByTagName('header').firstChild.data;</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  使用firstChild.data可以允许你存取该元素中的文本:</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  response.getElementsByTagName('header').firstChild.data;</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  下面是怎样创建这些代码的完整的例子:</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  var response = request.respon***ML.documentElement;&nbsp;<br>  var header = response.getElementsByTagName('header').firstChild.data;&nbsp;<br>  document.getElementById('copy').innerHTML = header;</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  八、需求分析</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  现在既然你知道怎样使用AJAX的基础知识,那么下一步就是决定是否在一工程使用它。须记住的最重要的事情是,在你还没有刷新页面时你无法使用"Back"按钮。为此,可以先专注于你的工程中的一小部分-它能够从使用这种类型的交互中受益。例如,你可以创建一个表单-它在用户每次输入一个输入字段或一个字母时查询一个脚本以便进行实时校验。你可以创建一个拖放页面-在释放一项时,它能够把数据发送到一个脚本中并把该页面的状态保存到一个数据库中。使用AJAX的理由毫无疑问是存在的; 并且这种使用无论对开发者还是用户都会带来益处; 这全依赖于具体的条件和执行情况。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  还有其它方法可用来解决"Back"按钮的问题,例如使用Google Gmail-它现在能够为你的操作提供一种撤消功能而不刷新该页面。以后还会出现许多更具创造性的例子-它们将通过提供给开发者创建独特实时的体验的手段给用户带来更大的好处。</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  九、结论</p><p style="padding-top: 0px; padding-right: 0px; padding-bottom: 0px; padding-left: 0px; margin-top: 1em; margin-right: 0px; margin-bottom: 0.5em; margin-left: 0px; ">  尽管AJAX允许我们构建新的和改进的方式来与一个WEB页面进行交互; 但是作为开发者,我们需要牢记产品是不考虑技术的; 它关心的是用户以及其如何与用户进行交互。没有了用户群,我们构建的工程毫无用处。基于这个标准,我们就能评估应该使用什么技术以及何时使用它们来创建对相应用户有用的应用。</p></div></div></span>
页: [1]
查看完整版本: Ajax xmlhttprequest原理