AJAX 的基礎

XMLHttpRequest AJAX 的基礎。

XMLHttpRequest對象

所有現代瀏覽器均支持 XMLHttpRequest 對象(IE5 和 IE6 使用ActiveXObject)。

XMLHttpRequest 用於在後臺與服務器交換數據。這意味着可以在不重新加載整個網頁的情況下,對網頁的某部分進行更新。

創建 XMLHttpRequest 對象

所有現代瀏覽器(IE7+、Firefox、Chrome、Safari 以及 Opera)均內建XMLHttpRequest 對象。

創建XMLHttpRequest 對象的語法:

variable=newXMLHttpRequest();

老版本的Internet Explorer (IE5 和 IE6)使用 ActiveX 對象:

variable=newActiveXObject("Microsoft.XMLHTTP");

爲了應對所有的現代瀏覽器,包括 IE5 和 IE6,請檢查瀏覽器是否支持 XMLHttpRequest 對象。如果支持,則創建XMLHttpRequest 對象。如果不支持,則創建ActiveXObject :

varxmlhttp;

if(window.XMLHttpRequest)

  {// code forIE7+, Firefox, Chrome, Opera, Safari

  xmlhttp=new XMLHttpRequest();

  }

else

  {// code for IE6,IE5

  xmlhttp=newActiveXObject("Microsoft.XMLHTTP");

  }

 

 

 

 

XMLHttpRequest對象用於和服務器交換數據。

向服務器發送請求

如需將請求發送到服務器,我們使用 XMLHttpRequest 對象的 open()和 send() 方法:

xmlhttp.open("GET","test1.txt",true);

xmlhttp.send();

方法

描述

open(method,url,async)

規定請求的類型、URL 以及是否異步處理請求。

·         method:請求的類型;GET 或 POST

·         url:文件在服務器上的位置

·         async:true(異步)或 false(同步)

send(string)

將請求發送到服務器。

·         string:僅用於 POST 請求

GET還是 POST?

與 POST 相比,GET 更簡單也更快,並且在大部分情況下都能用。

然而,在以下情況中,請使用 POST 請求:

·  無法使用緩存文件(更新服務器上的文件或數據庫)

·  向服務器發送大量數據(POST 沒有數據量限制)

·  發送包含未知字符的用戶輸入時,POST 比 GET 更穩定也更可靠

GET請求

一個簡單的 GET 請求:

xmlhttp.open("GET","demo_get.asp",true);

xmlhttp.send();

親自試一試

在上面的例子中,您可能得到的是緩存的結果。

爲了避免這種情況,請向 URL 添加一個唯一的 ID:

xmlhttp.open("GET","demo_get.asp?t="+ Math.random(),true);

xmlhttp.send();

親自試一試

如果您希望通過 GET 方法發送信息,請向 URL 添加信息:

xmlhttp.open("GET","demo_get2.asp?fname=Bill&lname=Gates",true);

xmlhttp.send();

親自試一試

POST請求

一個簡單 POST 請求:

xmlhttp.open("POST","demo_post.asp",true);

xmlhttp.send();

親自試一試

如果需要像 HTML 表單那樣 POST 數據,請使用 setRequestHeader() 來添加 HTTP 頭。然後在 send()方法中規定您希望發送的數據:

xmlhttp.open("POST","ajax_test.asp",true);

xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");

xmlhttp.send("fname=Bill&lname=Gates");

親自試一試

方法

描述

setRequestHeader(header,value)

向請求添加 HTTP 頭。

·         header: 規定頭的名稱

·         value: 規定頭的值

url- 服務器上的文件

open() 方法的 url參數是服務器上文件的地址:

xmlhttp.open("GET","ajax_test.asp",true);

該文件可以是任何類型的文件,比如 .txt 和 .xml,或者服務器腳本文件,比如 .asp 和 .php (在傳回響應之前,能夠在服務器上執行任務)。

異步 - True 或 False?

AJAX 指的是異步JavaScript 和 XML(AsynchronousJavaScript and XML)。

XMLHttpRequest 對象如果要用於 AJAX 的話,其 open() 方法的 async 參數必須設置爲 true:

xmlhttp.open("GET","ajax_test.asp",true);

對於 web 開發人員來說,發送異步請求是一個巨大的進步。很多在服務器執行的任務都相當費時。AJAX 出現之前,這可能會引起應用程序掛起或停止。

通過 AJAX,JavaScript無需等待服務器的響應,而是:

·  在等待服務器響應時執行其他腳本

·  當響應就緒後對響應進行處理

Async= true

當使用async=true 時,請規定在響應處於onreadystatechange 事件中的就緒狀態時執行的函數:

xmlhttp.onreadystatechange=function()

  {

  if (xmlhttp.readyState==4 &&xmlhttp.status==200)

    {

   document.getElementById("myDiv").innerHTML=xmlhttp.responseText;

    }

  }

xmlhttp.open("GET","test1.txt",true);

xmlhttp.send();

親自試一試

您將在稍後的章節學習更多有關 onreadystatechange 的內容。

Async= false

如需使用async=false,請將 open() 方法中的第三個參數改爲 false:

xmlhttp.open("GET","test1.txt",false);

我們不推薦使用 async=false,但是對於一些小型的請求,也是可以的。

請記住,JavaScript會等到服務器響應就緒才繼續執行。如果服務器繁忙或緩慢,應用程序會掛起或停止。

註釋:當您使用 async=false 時,請不要編寫 onreadystatechange 函數 - 把代碼放到 send()語句後面即可:

xmlhttp.open("GET","test1.txt",false);

xmlhttp.send();

document.getElementById("myDiv").innerHTML=xmlhttp.responseText;

親自試一試

服務器響應

如需獲得來自服務器的響應,請使用 XMLHttpRequest 對象的responseText 或 responseXML 屬性。

屬性

描述

responseText

獲得字符串形式的響應數據。

responseXML

獲得 XML 形式的響應數據。

responseText屬性

如果來自服務器的響應並非 XML,請使用responseText 屬性。

responseText 屬性返回字符串形式的響應,因此您可以這樣使用:

document.getElementById("myDiv").innerHTML=xmlhttp.responseText;

親自試一試

responseXML屬性

如果來自服務器的響應是 XML,而且需要作爲 XML對象進行解析,請使用 responseXML 屬性:

請求 books.xml 文件,並解析響應:

xmlDoc=xmlhttp.responseXML;

txt="";

x=xmlDoc.getElementsByTagName("ARTIST");

for(i=0;i<x.length;i++)

  {

  txt=txt + x[i].childNodes[0].nodeValue +"<br />";

  }

document.getElementById("myDiv").innerHTML=txt;

親自試一試

onreadystatechange事件

當請求被髮送到服務器時,我們需要執行一些基於響應的任務。

每當readyState 改變時,就會觸發 onreadystatechange 事件。

readyState 屬性存有XMLHttpRequest 的狀態信息。

下面是XMLHttpRequest 對象的三個重要的屬性:

屬性

描述

onreadystatechange

存儲函數(或函數名),每當 readyState 屬性改變時,就會調用該函數。

readyState

存有 XMLHttpRequest 的狀態。從 0 到 4 發生變化。

·         0: 請求未初始化

·         1: 服務器連接已建立

·         2: 請求已接收

·         3: 請求處理中

·         4: 請求已完成,且響應已就緒

status

200: "OK"

404: 未找到頁面

在onreadystatechange 事件中,我們規定當服務器響應已做好被處理的準備時所執行的任務。

當readyState 等於 4 且狀態爲 200 時,表示響應已就緒:

xmlhttp.onreadystatechange=function()

  {

  if (xmlhttp.readyState==4 &&xmlhttp.status==200)

    {

   document.getElementById("myDiv").innerHTML=xmlhttp.responseText;

    }

  }

親自試一試

註釋:onreadystatechange 事件被觸發 4 次,對應着 readyState 的每個變化。

使用 Callback 函數

callback 函數是一種以參數形式傳遞給另一個函數的函數。

如果您的網站上存在多個 AJAX 任務,那麼您應該爲創建XMLHttpRequest 對象編寫一個標準的函數,併爲每個 AJAX 任務調用該函數。

該函數調用應該包含 URL 以及發生 onreadystatechange 事件時執行的任務(每次調用可能不盡相同):

functionmyFunction()

{

loadXMLDoc("ajax_info.txt",function()

  {

  if (xmlhttp.readyState==4 &&xmlhttp.status==200)

    {

   document.getElementById("myDiv").innerHTML=xmlhttp.responseText;

    }

  });

}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章