pragma指令简介(转)

在使用XMLHttpRequest对象发送请求和处理响应之前,必须先用JavaScript创建一个XMLHttpRequest对象。 

Internet ExplorerXMLHttpRequest实现为一个ActiveX对象,其他浏览器(如FirefoxSafariOpera)把它实现为一个本地JavaScript对象。由于存在这些差别,JavaScript代码中必须包含有关的逻辑,从而使用ActiveX技术或者使用本地JavaScript对象技术来创建XMLHttpRequest的一个实例。

代码清单2-1展示了编写跨浏览器的JavaScript代码来创建XMLHttpRequest对象实例是多么简单。

代码清单2-1 创建XMLHttpRequest对象的一个实例

var  xmlHttp;

function createXMLHttpRequest() 
{

    
if (window.ActiveXObject) 
{

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

    }

    
else if (window.XMLHttpRequest) {

        xmlHttp 
= new
 XMLHttpRequest();

    }

}


 

2-1显示了XMLHttpRequest对象的一些典型方法。不要担心,稍后就会详细介绍这些方法。

2-1 标准XMLHttpRequest操作

   
   
abort()
停止当前请求
getAllResponseHeaders()
HTTP 请求的所有响应首部作为键 / 值对返回
getResponseHeader("header")
返回指定首部的串值
open("method", "url")
建立对服务器的调用。 method 参数可以是 GET POST PUT url 参数可以是相对 URL 或绝对 URL 。这个方法还包括 3 个可选的参数
send(content)
向服务器发送请求
setRequestHeader("header", "value")
把指定首部设置为所提供的值。在设置任何首部之前必须先调用 open()

void abort()

顾名思义,这个方法就是要停止请求。

string getAllResponseHeaders()

这个方法的核心功能对Web应用开发人员应该很熟悉了,它返回一个串,其中包含HTTP请求的所有响应首部,首部包括Content-LengthDateURI

string getResponseHeader(string header)

这个方法与getAllResponseHeaders()是对应的,不过它有一个参数表示你希望得到的指定首部值,并且把这个值作为串返回。

void open(string method, string url, boolean asynch, string username, string password)

这个方法会建立对服务器的调用。这是初始化一个请求的纯脚本方法。它有两个必要的参数,还有3个可选参数。要提供调用的特定方法(GETPOSTPUT),还要提供所调用资源的URL。另外还可以传递一个Boolean值,指示这个调用是异步的还是同步的。默认值为true,表示请求本质上是异步的。如果这个参数为false,处理就会等待,直到从服务器返回响应为止。由于异步调用是使用Ajax的主要优势之一,所以倘若将这个参数设置为false,从某种程度上讲与使用XMLHttpRequest对象的初衷不太相符。不过,前面已经说过,在某些情况下这个参数设置为false也是有用的,比如在持久存储页面之前可以先验证用户的输入。最后两个参数不说自明,允许你指定一个特定的用户名和密码。

void send(content)

这个方法具体向服务器发出请求。如果请求声明为异步的,这个方法就会立即返回,否则它会等待直到接收到响应为止。可选参数可以是DOM对象的实例、输入流,或者串。传入这个方法的内容会作为请求体的一部分发送。

void setRequestHeader(string header, string value)

这个方法为HTTP请求中一个给定的首部设置值。它有两个参数,第一个串表示要设置的首部,第二个串表示要在首部中放置的值。需要说明,这个方法必须在调用open()之后才能调用。

在所有这些方法中,最有可能用到的就是 open() send()
除了这些标准方法,XMLHttpRequest对象还提供了许多属性,如表2-2所示。处理XMLHttpRequest时可以大量使用这些属性。
2-2 标准XMLHttpRequest属性
   
   
onreadystatechange
每个状态改变时都会触发这个事件处理器,通常会调用一个JavaScript函数
readyState
请求的状态。有5个可取值:0 = 未初始化,1 = 正在加载,2 = 已加载,3 = 交互中,4 = 完成
responseText
服务器的响应,表示为一个串
responseXML
服务器的响应,表示为XML。这个对象可以解析为一个DOM对象
status
服务器的HTTP状态码(200对应OK404对应Not Found(未找到),等等)
statusText
HTTP状态码的相应文本(OKNot Found(未找到)等等)
 
2-1显示了Ajax应用中标准的交互模式。

2-1 标准Ajax交互

1.客户引发事件 2.xhr 3.callback()执行回应

一个简单的交互例子

 一个客户端事件触发一个Ajax事件。、

<input type="text"d="email" name="email" οnblur="validateEmail()";>

 创建XMLHttpRequest对象的一个实例。使用open()方法建立调用,并设置URL以及所希望的HTTP方法(通常是GETPOST)。请求实际上通过一个send()方法调用触发。可能的代码如下所示:

var xmlHttp;

function validateEmail() {

   var email = document.getElementById("email");

   var url = "validate?email=" + escape(email.value);

   if (window.ActiveXObject) {    

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

   }else if (window.XMLHttpRequest) {

        xmlHttp = new XMLHttpRequest();

   }

xmlHttp.open("GET", url);

xmlHttp.onreadystatechange = callback;

xmlHttp.send(null);

} 

向服务器做出请求。可能调用servletCGI脚本,或者任何服务器端技术。

   服务器可以做你想做的事情,包括访问数据库,甚至访问另一个系统。

   请求返回到浏览器。Content-Type设置为text/xml——XMLHttpRequest对象只能处理text/html类型的结果。在另外一些更复杂示例中,响应可能涉及更广,还包括JavaScriptDOM管理以及其他相关的技术。需要说明,你还需要设置另外一些首部,使浏览器不会在本地缓存结果。为此可以使用下面的代码:

response.setHeader("Cache-Control", "no-cache");

response.setHeader("Pragma", "no-cache");

<META HTTP-EQUIV="pragma" CONTENT="no-cache">
       <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate">
       <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

在这个示例中,XMLHttpRequest对象配置为处理返回时要调用callback()函数。这个函数会检查XMLHttpRequest对象的readyState属性,然后查看服务器返回的状态码。如果一切正常,callback()函数就会在客户端上做些有意思的工作。以下就是一个典型的回调方法:

function callback() {

     if (xmlHttp.readyState == 4) {//请求完成

     if (xmlHttp.status == 200) {    //对应OK

          //do something interesting here

             做些操作。。。。。。。。。。。。

     }

   }

}

显然,在创建和建立XMLHttpRequest对象时还可以做些事情,另外当“回调”函数完成了状态检查之后也可以有所作为。一般地,你会把这些标准调用包装在一个库中,以便在整个应用中使用,或者可以使用Web上提供的库。

一些比较成熟的库包括libXmlRequestRSLitesarissaJavaScript对象注解(JavaScript Object NotationJSON)、JSRS、直接Web远程通信(Direct Web RemotingDWR)和Rails on Ruby。这个领域日新月异,所以应当适当地配置你的RSS收集器,及时收集有关Ajax的所有网站上的信息!

你可能想了解 GETPOST之间有什么区别,并想知道什么时候使用它们。从理论上讲,如果请求是幂等的就可以使用 GET,所谓幂等是指多个请求返回相同的结果。实际上,相应的服务器方法可能会以某种方式修改状态,所以一般情况下这是不成立的。这只是一种标准。更实际的区别在于净荷的大小,在许多情况下,浏览器和服务器会限制URL的长度URL用于向服务器发送数据。一般来讲,可以使用 GET从服务器获取数据;换句话说,要避免使用 GET调用改变服务器上的状态。
一般地,当改变服务器上的状态时应当使用 POST方法。不同于 GET,需要设置XML- HttpRequest对象的 Content-Type首部,如下所示:
xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
GET不同, POST不会限制发送给服务器的净荷的大小,而且 POST请求不能保证是幂等的。
你做的大多数请求可能都是 GET请求,不过,如果需要,也完全可以使用 POST
我做的例子代码
< html >
< head >
< META  HTTP-EQUIV ="pragma"  CONTENT ="no-cache" >
< META  HTTP-EQUIV ="Cache-Control"  CONTENT ="no-cache, must-revalidate" >
< meta  http-equiv ="Content-Type"  content ="text/html; charset=UTF-8" >
</ head >
< body >

email:   
< input  type ="text" d ="email"  name ="email"  onblur ="validateEmail()" ; >
< script  language ="javascript" >
var xmlHttp;

function validateEmail() {

   
var email = document.getElementById("email");

   
var url = "validate?email=" + escape(email.value);

   
if (window.ActiveXObject) {
     xmlHttp 
= new ActiveXObject("Microsoft.XMLHTTP");
   }

   
else if (window.XMLHttpRequest) {
     xmlHttp 
= new XMLHttpRequest();
   }


xmlHttp.open(
"GET", url);

xmlHttp.onreadystatechange 
= callback;

xmlHttp.send(
null);

}


function callback() {

   
if (xmlHttp.readyState == 4{           //请求完成

     
if (xmlHttp.status == 200{            //OK

          
//do something interesting here
          alert("123");

     }


   }

   
else{                              //失败
        alert("456");
   }


}

</ script >
</ body >
</ html >
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值