欧美激情网,国产欧美亚洲高清,欧美屁股xxxxx,欧美群妇大交群,欧美人与物ⅴideos另类,区二区三区在线 | 欧洲

知識(shí)學(xué)堂
  • ·聯(lián)系電話:+86.023-75585550
  • ·聯(lián)系傳真:+86.023-75585550
  • ·24小時(shí)手機(jī):13896886023
  • ·QQ 咨 詢:361652718 513960520
當(dāng)前位置 > 首頁(yè) > 知識(shí)學(xué)堂 > 網(wǎng)站建設(shè)知識(shí)
AJAX教程(12):AJAX ResponseXML 實(shí)例
更新時(shí)間:2011-12-19 | 發(fā)布人:本站 | 點(diǎn)擊率:281

與 responseText 以字符串返回 HTTP 響應(yīng)不同,responseXML 以 XML 返回響應(yīng)。

ResponseXML 屬性返回 XML 文檔對(duì)象,可使用 W3C DOM 節(jié)點(diǎn)樹的方法和屬性來檢查和解析該對(duì)象。

AJAX ResponseXML 實(shí)例

在下面的 AJAX 實(shí)例中,我們將演示網(wǎng)頁(yè)如何使用 AJAX 技術(shù)從數(shù)據(jù)庫(kù)中讀取信息。這次,這些從數(shù)據(jù)庫(kù)中選取的數(shù)據(jù)將被轉(zhuǎn)換為 XML 文檔,然后我們將使用 DOM 來提取要顯示的值。

選取下拉列表中的名稱

AJAX 實(shí)例解釋

上面的例子包含一個(gè) HTML 表單,若干個(gè)保留所返回?cái)?shù)據(jù)的 <span> 元素,以及指向一段 JavaScript 的鏈接:

<html>
<head>
<script src="selectcustomer_xml.js"></script>
</head>
<body>

<form action=""> 
<label>選擇客戶:
<select name="customers" onchange="showCustomer(this.value)">
<option value="ALFKI">Alfreds Futterkiste</option>
<option value="NORTS ">North/South</option>
<option value="WOLZA">Wolski Zajazd</option>
</select></label>
</form>

<b><span id="companyname"></span></b><br />
<span id="contactname"></span><br />
<span id="address"></span>
<span id="city"></span><br/>
<span id="country"></span>

</body>
</html>

上面的例子包含了一個(gè) HTML 表單,該表單帶有一個(gè)名為 "customers" 下拉框。

當(dāng)用戶選取下拉框中的客戶時(shí),函數(shù) "showCustomer()" 就會(huì)被執(zhí)行。事件 "onchange" 會(huì)觸發(fā)該函數(shù)執(zhí)行。換句話說,每當(dāng)用戶改變下拉框中的值時(shí),函數(shù) showCustomer() 就會(huì)被調(diào)用。

下面列出了 JavaScript 代碼。

AJAX JavaScript

這是存儲(chǔ)在文件 "selectcustomer_xml.js" 中的 JavaScript 代碼:

var xmlHttp

function showCustomer(str)
{ 
xmlHttp=GetXmlHttpObject();
if (xmlHttp==null)
  {
  alert ("Your browser does not support AJAX!");
  return;
  }
var url="getcustomer_xml.asp";
url=url+"?q="+str;
url=url+"&sid="+Math.random();
xmlHttp.onreadystatechange=stateChanged;
xmlHttp.open("GET",url,true);
xmlHttp.send(null);
}

function stateChanged() 
{ 
if (xmlHttp.readyState==4)
{
var xmlDoc=xmlHttp.responseXML.documentElement;
document.getElementById("companyname").innerHTML=
xmlDoc.getElementsByTagName("compname")[0].childNodes[0].nodeValue;
document.getElementById("contactname").innerHTML=
xmlDoc.getElementsByTagName("contname")[0].childNodes[0].nodeValue;
document.getElementById("address").innerHTML=
xmlDoc.getElementsByTagName("address")[0].childNodes[0].nodeValue;
document.getElementById("city").innerHTML=
xmlDoc.getElementsByTagName("city")[0].childNodes[0].nodeValue;
document.getElementById("country").innerHTML=
xmlDoc.getElementsByTagName("country")[0].childNodes[0].nodeValue;
}
}

function GetXmlHttpObject()
{
var xmlHttp=null;
try
  {
  // Firefox, Opera 8.0+, Safari
  xmlHttp=new XMLHttpRequest();
  }
catch (e)
  {
  // Internet Explorer
  try
    {
    xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
    }
  catch (e)
    {
    xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
    }
  }
return xmlHttp;
}

showCustomer() 和 GetXmlHttpObject() 與上一節(jié)相同。stateChanged() 函數(shù)稍早前也在本教程中使用過。不過,這次我們通過 responseXML 以 XML 文檔返回結(jié)果,并使用 DOM 來提取要顯示的值。

AJAX 服務(wù)器頁(yè)面

這個(gè)被 JavaScript 調(diào)用的服務(wù)器頁(yè)面,是名為 "getcustomer_xml.asp" 的簡(jiǎn)單 ASP 文件。

該頁(yè)面使用 VBScript 編寫,針對(duì) Internet 信息服務(wù)器 (IIS)?梢杂 PHP 或其他服務(wù)器語(yǔ)言,簡(jiǎn)單地重寫該頁(yè)面。

請(qǐng)看在 PHP 中對(duì)應(yīng)的例子(測(cè)試:缺具體頁(yè)面)。

這段代碼執(zhí)行針對(duì)數(shù)據(jù)庫(kù)的 SQL 查詢,并以 XML 文檔返回結(jié)果:

<%
response.expires=-1
response.contenttype="text/xml"

sql="SELECT * FROM CUSTOMERS "
sql=sql & " WHERE CUSTOMERID='" & request.querystring("q") & "'"

on error resume next
set conn=Server.CreateObject("ADODB.Connection")
conn.Provider="Microsoft.Jet.OLEDB.4.0"
conn.Open(Server.Mappath("/db/northwind.mdb"))
set rs=Server.CreateObject("ADODB.recordset")
rs.Open sql, conn

if err <> 0 then
response.write(err.description)
set rs=nothing
set conn=nothing
else
response.write("<?xml version='1.0' encoding='ISO-8859-1'?>")
response.write("<company>")
response.write("<compname>" &rs.fields("companyname")& "</compname>")
response.write("<contname>" &rs.fields("contactname")& "</contname>")
response.write("<address>" &rs.fields("address")& "</address>")
response.write("<city>" &rs.fields("city")& "</city>")
response.write("<country>" &rs.fields("country")& "</country>")
response.write("</company>")
end if
on error goto 0
%>

請(qǐng)注意上面的 ASP 代碼中的第二行:response.contenttype="text/xml"。ContentType 屬性為 response 對(duì)象設(shè)置了 HTTP 內(nèi)容類型。該屬性的默認(rèn)值是 "text/html"。這次我們把內(nèi)容類型設(shè)置為 XML。

然后我們從數(shù)據(jù)庫(kù)中選取數(shù)據(jù),并使用這些數(shù)據(jù)構(gòu)建 XML 文檔。