Ajax中怎么讀取數(shù)據(jù)到表格

Ajax中怎么讀取數(shù)據(jù)到表格,相信很多沒(méi)有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。

創(chuàng)新互聯(lián)主營(yíng)閬中網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,重慶App定制開發(fā),閬中h5小程序定制開發(fā)搭建,閬中網(wǎng)站營(yíng)銷推廣歡迎閬中等地區(qū)企業(yè)咨詢

代碼如下:


<%
'出自:http://Www.Web666.Net
'作者:康董
'如需轉(zhuǎn)載請(qǐng)務(wù)必保留以上信息
'定義一個(gè)變量,來(lái)保存xml數(shù)據(jù)
dim xml
xml = "<?xml version='1.0' encoding='gb2312'?><body>"
xml = xml&"<msg>一個(gè)簡(jiǎn)單的Asp輸出xml的示例,以后在我們的ajax教程實(shí)例中,我們都將使用該文件進(jìn)行數(shù)據(jù)的讀取操作</msg>"
xml=xml&"</body>"
Response.Clear
Response.ContentType="text/xml"
Response.CharSet="gb2312"
Response.Write xml
Response.End
%>


上次我們讀取的是msg標(biāo)簽.今天我們要讀取xml中新增的read標(biāo)簽.我們要實(shí)現(xiàn)的效果是:將read標(biāo)簽下的Html,Css,Dom,JavaScript,Ajax這些文本內(nèi)容.顯示到我們網(wǎng)頁(yè)中的表格內(nèi).
先看下面的代碼.和實(shí)例演示

復(fù)制代碼 代碼如下:


<html>
<head>
<title>ajax讀取數(shù)據(jù)到表格</title>
</head>
<body>
<input type="button" value="顯示數(shù)據(jù)" onclick="Post()" />
<script type="text/javascript">
function ajax_xmlhttp(){
//在IE中創(chuàng)建xmlhttpRequest,適用于IE5.0以上所有版本
var msXmlhttp = new Array("Msxml2.XMLHTTP.5.0","Msxml2.XMLHTTP.4.0","Msxml2.XMLHTTP.3.0","Msxml2.XMLHTTP","Microsoft.XMLHTTP");
for(var i=0; i<msXmlhttp.length; i++){
try
{
_xmlhttp=new ActiveXObject(msXmlhttp[i]);
}
catch(e)
{
_xmlhttp=null;
}
} //循環(huán)創(chuàng)建基于IE瀏覽器的xmlhttp.結(jié)束
//如果非IE瀏覽器,則創(chuàng)建基于FireFox等瀏覽器的xmlhttpRequest
if(!_xmlhttp && typeof XMLHttpRequest != "undefined")
{
_xmlhttp=new XMLHttpRequest();
}
return _xmlhttp;
}

//發(fā)送請(qǐng)求函數(shù)
function Post(){
var ajax = ajax_xmlhttp(); //將xmlhttprequest對(duì)象賦值給一個(gè)變量.
ajax.open("post","web_ajax.asp",true);//設(shè)置請(qǐng)求方式,請(qǐng)求文件,異步請(qǐng)求
ajax.onreadystatechange = function(){//你也可以這里指定一個(gè)已經(jīng)寫好的函數(shù)名稱
if(ajax.readyState==4){//數(shù)據(jù)返回成功
if(ajax.status==200){//http請(qǐng)求狀態(tài)碼返回ok
var xmlData = ajax.responseXML;//接收返回xml格式數(shù)據(jù)
var read = xmlData.getElementsByTagName("read");//獲取所有的read標(biāo)簽
if(read.length!=0){
var t = document.createElement("table");//創(chuàng)建一個(gè)表格元素
t.setAttribute("border","1");
document.body.appendChild(t);//將表格添加到doby內(nèi)
for(var i=0;i<read[0].childNodes.length;i++){
var tr = t.insertRow(t.rows.length);//添加一行
var td = tr.insertCell(0);//添加一列
td.innerHTML = read[0].childNodes[i].firstChild.nodeValue;//為單元格寫入文本內(nèi)容
}
}
}
}
}
ajax.send(null);
}
</script>
</body>
</html>


今天我們不再講昨天重復(fù)過(guò)的內(nèi)容.同樣在Post的函數(shù)內(nèi).多了幾行代碼.可以跟上一篇"ajax初始讀取數(shù)據(jù)篇"進(jìn)行對(duì)比.
下面我們來(lái)講一下今天新增的代碼的作用.

if read.length!=0:即判斷read標(biāo)簽是否被成功獲?。绻鋖egnth屬性不等于0,則代表read已經(jīng)存在.可以對(duì)其進(jìn)行解析
開始解析返回?cái)?shù)據(jù),但網(wǎng)頁(yè)中并沒(méi)有存在顯示數(shù)據(jù)的元素.所以我們創(chuàng)建一個(gè)表格:var t = document.createElement("table");.請(qǐng)參考:createElement
t.setAttribute("border","1");為表格添加一個(gè)邊框?qū)傩裕?qǐng)參考:setAttribute
document.body.appendChild(t);將創(chuàng)建好的表格添加到網(wǎng)頁(yè)body元素內(nèi).請(qǐng)參考:appendChild
表格添加完成.開始遍歷read標(biāo)簽內(nèi)的所有子元素.也就是:html,css,dom,javascript,ajax這些內(nèi)容.
開始一個(gè)循環(huán),read[0].childNodes.length的意思是獲取read標(biāo)簽內(nèi)所有子元素的個(gè)數(shù).在這里會(huì)返回5. i=0;i<5條件ok! 每循環(huán)一次i變量會(huì)自動(dòng)+1,表格會(huì)增加一行,并為該行增加一列.同時(shí)為這一列寫入read第i個(gè)子元素的文本內(nèi)容.直到i=5,i不會(huì)再小于read子元素的個(gè)數(shù).條件不滿足.循環(huán)停止.此時(shí)數(shù)據(jù)正好被顯示完畢!
為了讓每位讀者加深理解.我再陳述一遍該實(shí)例效果的實(shí)現(xiàn)流程:當(dāng)你點(diǎn)擊了"顯示數(shù)據(jù)"按扭時(shí),Post函數(shù)被啟用,函數(shù)內(nèi)一個(gè)名字為ajax的變量被賦值XMLHTTPRequest對(duì)象的引用.然后便打開了open方法.并使用send方法向服務(wù)端發(fā)出請(qǐng)求.無(wú)論是open還是send方法,都會(huì)引發(fā)readyState方法的狀態(tài)值發(fā)生變化.一旦readyState發(fā)生變化就會(huì)觸發(fā)onreadystatechange屬性. onreadystatechange屬性指定的程序?qū)?huì)執(zhí)行.然后在程序內(nèi)再次判斷readyState的狀態(tài)值是否等于4,如果是則證明整個(gè)發(fā)送請(qǐng)求與服務(wù)端返回?cái)?shù)據(jù)已經(jīng)成功.同時(shí)并判斷status是否等200,如果是則代表http請(qǐng)狀態(tài)碼也已經(jīng)ok!此時(shí)可以放心的百分之百的接收數(shù)據(jù),于是我們使用responseXML屬性來(lái)接收返回的數(shù)據(jù).該屬性只限制接收xml格式的數(shù)據(jù).我始終認(rèn)為將xml格式的數(shù)據(jù)做為請(qǐng)求與回傳的中介.是ajax最標(biāo)準(zhǔn)的使用方法!

看完上述內(nèi)容,你們掌握Ajax中怎么讀取數(shù)據(jù)到表格的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

網(wǎng)頁(yè)標(biāo)題:Ajax中怎么讀取數(shù)據(jù)到表格
當(dāng)前URL:http://bm7419.com/article18/pciodp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供手機(jī)網(wǎng)站建設(shè)網(wǎng)站改版、搜索引擎優(yōu)化、App開發(fā)標(biāo)簽優(yōu)化、品牌網(wǎng)站設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化