`
paulwong
  • 浏览: 74375 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

AJAX 上手篇

    博客分类:
  • AJAX
阅读更多

AJAX 上手篇<o:p></o:p>

<o:p> </o:p>

第一步 – 说声「请」 (又称为「怎么发出 XMLHttpRequest」) <o:p></o:p>

为了用 JavaScript 对服务器发送 HTTP 要求,你必须先以相关的类别(class)制出实体(instance)。Internet
Explorer 首先以 ActiveX 对象方式提供 XMLHTTP 类别,而 Mozilla、Safari及其它浏览器则随后以 XMLHttpRequest 类别支持此 ActiveX 对象中的类别及属性。 <o:p></o:p>


因此,如果想跨浏览器,那么可以这么写: 


<o:p> </o:p>

<!----> if  (window.XMLHttpRequest) {  //  Mozilla, Safari, 

    http_request 
=   new  XMLHttpRequest();

else   if  (window.ActiveXObject) {  //  IE

    http_request 
=   new  ActiveXObject( " Microsoft.XMLHTTP " );

}

<o:p> </o:p>


(由于这段程序仅供说明,所以是采最简方式写出。本文第三步中有另一种我们比较常用的写法。) <o:p></o:p>

有些版本的 Mozilla 浏览器在服务器送回的数据未含 XML mime-type 文件头(header)时会出错。为了避免这个问题,你可以用下列方法覆写服务器传回的档头,以免传回的不是text/xml


<o:p> </o:p>

<!----> http_request  =   new  XMLHttpRequest();

http_request.overrideMimeType('text
/ xml');
<o:p> </o:p>


接下来是要决定服务器传回资料后的处理方式,此时你只要以 onreadystatechange 这个属性指明要处理传回值的
JavaScript 函式名称即可,例如:


<o:p> </o:p>

<!----> http_request.onreadystatechange  =  nameOfTheFunction;

<o:p> </o:p>

注意,指定的函式名称后不加括号也没有参数。除了指定函式名称外,你也能用 Javascript 实时定义函式的方法来定一个新的处理函式,如下:


<o:p> </o:p>

<!----> http_request.onreadystatechange  =   function (){

    
//  做些事

};
<o:p> </o:p>


决定处理方式之后你得确实发出 request,此时需叫用 HTTP request 类别的 open()send() 方法,如下:


<o:p> </o:p>

<!----> http_request.open('GET', 'http: // www.example.org/some.file', true);
http_request.send( null );

<o:p> </o:p>
  • open() 的第一个参数是
         HTTP request 的方法,也就是从
         GET、POST、HEAD 中择一使用,亦可用你主机上支持的方式。为遵循 HTTP 标准,请记得这些方法都是大写,不然有的浏览器(如 Firefox)或许不会理你。其它 HTTP request 可以支持的方法列表请参考
         W3C 规格书 (http://www.w3.org/Protocols/rfc2616/rfc2616-sec9.html)。 <o:p></o:p>
  • 第二个参数是目标 URL。基于安全考虑,你不能叫用同网域以外的网页。如果网域不同,则叫用
         open() 时会出现「权限不足,拒绝存取」那类的错误。通常大伙会犯的错误多为在 domain.tld 网的网站下呼叫 www.domain.tld 中的网页,仅是一点点差别都不行。
         <o:p></o:p>
  • 第三个参数决定此 request 是否不同步进行,如果设定为
         TRUE 则即使服务器尚未传回数据也会继续执行其余的程序,这也就是 AJAX 中第一个 A 代表的意义。 <o:p></o:p>

send() 的参数在以 POST 发出 request 时可以是任何想传给服务器的东西,而数据则以查询字符串的方式列出,例如: <o:p></o:p>

 

<!----> name = value & anothername = othervalue & so = on
<o:p> </o:p>

不过如果你想要以 POST 方式传送数据,则必须先将 MIME 型态改好,如下: <o:p></o:p>

				

<!---->
http_request.setRequestHeader('Content
-
Type', 'application
/
x
-
www
-
form
-
urlencoded');





<o:p>
</o:p>

否则服务器就不会理你传过来的数据了。 <o:p></o:p>

第二步 – 「就上咩!」(又称为「处理服务器传回的数据」) <o:p></o:p>

传出 request 时必须提供处理传回值的函式名称。 <o:p></o:p>

<!----> http_request.onreadystatechange  =  nameOfTheFunction;

<o:p> </o:p>

////////////////////////////////////////////////////////////////////<o:p></o:p>
//但是,FireFox 对onreadyStateChange没有反应,怎么办,这个方法不能用在<o:p></o:p>
//FireFox 中,有没有其它的方法?<o:p></o:p>
//      Added by www.besook.com 2006-03-19<o:p></o:p>
//////////////////////////////////////////////////////////////<o:p></o:p>

那么来看看这个函式该做些什么。首先,它必须检查 request 目前的状态:如果状态值为 4 代表服务器已经传回所有信息了,便可以开始解析所得信息。


<o:p> </o:p>

<!----> if  (http_request.readyState  ==   4 ) {

    
//  一切 ok, 继续解析

else  {

    
//  还没完成

}
<o:p> </o:p>


readyState 所有可能的值如下: <o:p></o:p>

  • 0 (还没开始) <o:p></o:p>
  • 1 (读取中) <o:p></o:p>
  • 2 (已读取) <o:p></o:p>
  • 3 (信息交换中) <o:p></o:p>
  • 4 (一切完成) <o:p></o:p>

(资料来源: MSDN (http://msdn.microsoft.com/workshop/author/dhtml/reference/properties/readystate_1.asp))
<o:p></o:p>

接下来要检查服务器传回的 HTTP 状态码。所有状态码列表可于 W3C
网站
(http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html)上查到,但我们要管的是200 OK 这种状态。


<o:p> </o:p>

<!----> if  (http_request.status  ==   200 ) {

    
//  万事具备

else  {

    
//  似乎有点问题,或许服务器传回了 404 (查无此页) 或者 500 (内部错误) 什么的

}
<o:p> </o:p>



检查传回的 HTTP 状态码后,要怎么处理传回的数据就由你决定了。有两种存取数据的方式: <o:p></o:p>

  • http_request.responseText – 这样会把传回值当字符串用
         <o:p></o:p>
  • http_request.responseXML – 这样会把传回值视为
         XMLDocument 对象,而后可用
         JavaScript DOM 相关函式处理 <o:p></o:p>

第三步 - 万事俱备 - 简单范例 <o:p></o:p>

好,接着就做一次简单的 HTTP 范例,演示方才的各项技巧。这段 JavaScript 会向服务器要一份里头有「I'm
a test.」字样的 HTML 文件(test.html),而后以 alert() 将文件内容列出。


<o:p> </o:p>

<!----> < script type = " text/javascript "  language = " javascript " >

    
var  http_request  =   false ;

    
function  makeRequest(url) {

        http_request 
=   false ;

        
if  (window.XMLHttpRequest) {  //  Mozilla, Safari,

            http_request 
=   new  XMLHttpRequest();

            
if  (http_request.overrideMimeType) {

                http_request.overrideMimeType('text
/ xml');

            }

        } 
else   if  (window.ActiveXObject) {  //  IE

            
try  {

                http_request 
=   new  ActiveXObject( " Msxml2.XMLHTTP " );

            } 
catch  (e) {

                
try  {

                    http_request 
=   new  ActiveXObject( " Microsoft.XMLHTTP " );

                } 
catch  (e) {}

            }

        }

        
if  ( ! http_request) {

            alert('Giving up :( Cannot create an XMLHTTP instance');

            
return   false ;

        }

        http_request.onreadystatechange 
=  alertContents;

        http_request.open('GET', url, 
true );

        http_request.send(
null );

    }

    
function  alertContents() {

        
if  (http_request.readyState  ==   4 ) {

            
if  (http_request.status  ==   200 ) {

                alert(http_request.responseText);

            } 
else  {

                alert('There was a problem 
with  the request.');

            }

        }

    }

</ script >

< span

    style
= " cursor: pointer; text-decoration: underline "

    onclick
= " makeRequest('test.html') " >

        Make a request

</ span >
<o:p> </o:p>


在此范例中: <o:p></o:p>

  • 首先使用者按下「Make a request」 <o:p></o:p>
  • 这么一来就会呼叫
         makeRequest() 函式,亦传入参数值 test.html (也就是那份 HTML 档的名称,放在同目录下) <o:p></o:p>
  • 接着发出 request,而后会将主导权交给
         onreadystatechange 指定的 alertContents() 函式 <o:p></o:p>
  • alertContents() 检查响应是否正常,而后以 alert()test.html 的内容列出 <o:p></o:p>

你可以由此测试本例 (http://www.w3clubs.com/mozdev/httprequest_test.html),也可以参考测试档案 (http://www.w3clubs.com/mozdev/test.html)。
<o:p></o:p>

第四步 – 「X 档案」(又称为「处理 XML 响应值」) <o:p></o:p>

前面的例子中,在收到 HTTP 传回值后我们以对象的 reponseText 属性使用 test.html 档案的内容,接着来试试 responseXML 属性的方法。 <o:p></o:p>

首先,我们得做个格式正确的 XML 文件,以便稍后取用。此档名唤 test.xml,内容如下:


<o:p> </o:p>

<!----> <? xml version="1.0"  ?>

< root >

    I'm a test.

</ root >
<o:p> </o:p>


在程序中,我们叫用档案的地方只须略事修改如下: <o:p></o:p>

...<o:p></o:p>
				

<!---->
onclick
=
"
makeRequest('test.xml')
"

<o:p>
</o:p>
...<o:p></o:p>

接着在 alertContents() 中,我们必须将 alert(http_request.responseText); 改成这样:


<o:p> </o:p>

<!----> var  xmldoc  =  http_request.responseXML;

var  root_node  =  xmldoc.getElementsByTagName('root').item( 0 );

alert(root_node.firstChild.data);

<o:p> </o:p>
这样一来我们便可取得 responseXML 所传回的 XMLDocument 对象,而后以 DOM 相关的方法取用
XML 文件内容。你可以参考 test.xml 的原始码 (http://www.w3clubs.com/mozdev/test.xml)
以及修改过后的测试程序 (http://www.w3clubs.com/mozdev/httprequest_test_xml.html)。
分享到:
评论

相关推荐

    [Ajax]Ajax中文手册(快速上手).rar

    1. **基础篇**:了解Ajax的基本概念和工作流程,熟悉XMLHttpRequest对象的方法和属性。 2. **实例篇**:通过简单示例,实践创建和发送Ajax请求,解析响应数据并更新页面。 3. **进阶篇**:学习处理错误、跨域问题,...

    apex,ajax相关资料

    本篇将深入探讨APEX和AJAX的相关知识,基于给定的文档信息,涵盖其核心概念、功能以及如何在实际开发中应用。 #### APEX与AJAX:概览 APEX是Salesforce.com为开发者提供的一种专有编程语言,用于构建自定义应用...

    AJAX初体验之上手篇

    AJAX(Asynchronous JavaScript and XML)是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。近年来,AJAX因其能够提升用户体验,使网页更加互动而备受关注。在本文中,我们将探讨如何开始使用AJAX,...

    ajax 三级联动

    本篇文章将深入探讨Ajax的三级联动实现,尤其适合初学者快速理解Ajax的异步传输机制。 ### 一、什么是Ajax三级联动? Ajax三级联动是指在网页中,通常在下拉框中,当用户选择一级选项时,根据一级选项的数据动态...

    ajax tool 使用

    本篇将详细介绍一个名为“Ajaxtool”的工具,它是开发者实现Ajax功能的有效辅助工具,尤其对于初学者来说,它能帮助理解Ajax的工作原理并快速上手。 首先,让我们了解一下Ajax的基本概念。Ajax的核心是...

    Advanced.ASP.NET.AJAX.Server.Controls.For.dot.NET.Framework.3.5.

    本书由 Adam Calderon 和 Joel Rumerman 共同撰写,通过深入浅出的方式介绍了 ASP.NET AJAX 控件的核心概念和技术细节,使读者能够快速上手并熟练运用这些技术。 #### 书籍价值与目标读者 本书得到了多位业界专家...

    Ajax分页条,内有使用方法

    本篇文章将深入探讨Ajax分页条的工作原理、实现方式以及如何自定义样式。 一、工作原理 Ajax分页条的核心是利用Ajax(Asynchronous JavaScript and XML)技术进行后台数据的异步加载。当用户点击分页按钮时,前端...

    AjaxDWR_Manual

    本篇文章将深入探讨AjaxDWR的手册内容,帮助开发者更好地理解和运用这一强大的工具。 ### 1. AjaxDWR概述 AjaxDWR是Java开发者使用Ajax的一个便捷框架,它简化了前端JavaScript与后台Java之间的交互过程。通过DWR...

    PHP+Ajax_Web_2.0编程技术与项目开发大全(部分)

    通过丰富的示例,读者可以快速上手,编写简单的PHP程序。 - **第3章:PHP的常用语句** 本章深入讲解了PHP中的流程控制语句,如条件语句(if、switch)、循环语句(for、while、do...while),以及控制流转移语句...

    ajax常用框架集

    本篇文章将主要探讨一个名为Scriptaculous的Ajax框架。 **Scriptaculous框架** Scriptaculous 是一个基于JavaScript的轻量级库,主要提供了丰富的动态效果和易于使用的Ajax功能。它依赖于Prototype JavaScript框架...

    DWR让AJAX如此简单.pdf

    本篇文章将深入探讨DWR与Ajax的关系、工作原理以及如何利用它们来提升Web应用的用户体验。 1. **DWR与Ajax**:DWR是基于Ajax技术的框架,它允许JavaScript在浏览器端与服务器端的Java对象进行实时通信,而无需刷新...

    java源码:国产Ajax框架 Buffalo.rar

    本篇将深入探讨一个国产Ajax框架——Buffalo,通过分析其源码,我们可以了解到该框架的设计理念、核心功能以及实现机制。 一、Buffalo框架简介 Buffalo是一个基于Java的轻量级Ajax框架,旨在简化Web应用中的异步...

    2024 Vue3快速上手 视频教程 下载 百度网盘链接2.zip

    │ 实战篇-43_ajax函数库axios基本使用.mp4 │ 实战篇-44_vue案例.mp4 │ 实战篇-45_vue工程化_准备环境.mp4 │ 实战篇-46_工程化_vue项目的创建和启动.mp4 │ 实战篇-47_工程化_vue项目开发流程.mp4 │ 实战篇...

    2024 Vue3快速上手 视频教程 下载 百度网盘链接4.zip

    │ 实战篇-43_ajax函数库axios基本使用.mp4 │ 实战篇-44_vue案例.mp4 │ 实战篇-45_vue工程化_准备环境.mp4 │ 实战篇-46_工程化_vue项目的创建和启动.mp4 │ 实战篇-47_工程化_vue项目开发流程.mp4 │ 实战篇...

    2024 Vue3快速上手 视频教程 下载 百度网盘链接1.zip

    │ 实战篇-43_ajax函数库axios基本使用.mp4 │ 实战篇-44_vue案例.mp4 │ 实战篇-45_vue工程化_准备环境.mp4 │ 实战篇-46_工程化_vue项目的创建和启动.mp4 │ 实战篇-47_工程化_vue项目开发流程.mp4 │ 实战篇...

    2024 Vue3快速上手 视频教程 下载 百度网盘链接3.zip

    │ 实战篇-43_ajax函数库axios基本使用.mp4 │ 实战篇-44_vue案例.mp4 │ 实战篇-45_vue工程化_准备环境.mp4 │ 实战篇-46_工程化_vue项目的创建和启动.mp4 │ 实战篇-47_工程化_vue项目开发流程.mp4 │ 实战篇...

    AJAX架构之Dojo篇

    Dojo提供了丰富的学习资源来帮助开发者快速上手: - **Dojo手册**:详尽介绍了Dojo的使用方法和示例代码。 - **邮件列表**:供开发者交流问题和改进建议。 - **错误跟踪系统**:报告和跟踪Dojo的bug。 - **代码仓库*...

    整合 Struts 2 + Spring 2 + JPA + AJAX

    这篇博文的快速启动文件(quickstart)旨在帮助开发者整合这些技术,构建一个高效、灵活且功能丰富的 Web 应用程序。下面将分别介绍这四个组件的核心概念及其整合方法。 1. **Struts 2**: Struts 2 是一款基于 ...

Global site tag (gtag.js) - Google Analytics