九色国产,午夜在线视频,新黄色网址,九九色综合,天天做夜夜做久久做狠狠,天天躁夜夜躁狠狠躁2021a,久久不卡一区二区三区

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費(fèi)電子書(shū)等14項(xiàng)超值服

開(kāi)通VIP
使用js解析xml文檔和xml字符串(ie和火狐)

原文:http://blog.csdn.net/lushuaiyin/article/details/7564631

使用js解析xml文檔和xml字符串。

 

分別針對(duì)ie和火狐分別作了對(duì)xml文檔和xml字符串的解析,所有代碼都注釋掉了,想看哪部分功能,

去掉注釋就可以了。

 

至于在ajax環(huán)境下解析xml,其實(shí)原理是一樣的,只不過(guò)放在了ajax里,還是要對(duì)返回的xml進(jìn)行解析。

 

  1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
  2. <html>  
  3.  <head>  
  4.   <title> New Document </title>  
  5.   <meta name="Author" content="lushuaiyin">  
  6.  </head>  
  7.  <body>  
  8.   用js解析xml文檔和xml字符串  
  9.  </body>  
  10. </html>  
  11.   
  12. <script>  
  13. //解析xml文檔/////////////////////////////////////////////////////  
  14. var xmlDoc=null;  
  15.   
  16. //支持IE瀏覽器  
  17. if(window.ActiveXObject){  
  18.    xmlDoc=new ActiveXObject("Microsoft.XMLDOM");   
  19. }  
  20. //支持Mozilla瀏覽器  
  21. else if(document.implementation && document.implementation.createDocument){  
  22.    xmlDoc = document.implementation.createDocument('','',null);  
  23. }  
  24. else{  
  25.   alert("here");  
  26. }  
  27. if(xmlDoc!=null){  
  28.    xmlDoc.async = false;  
  29.    xmlDoc.load("house.xml");  
  30. }  
  31.   
  32. //ie和火狐不僅解析器不一樣,解析過(guò)程也不一樣。如下;  
  33. //ie解析xml文檔  
  34. //alert(xmlDoc.getElementsByTagName("address")[0].childNodes[0].childNodes[0].childNodes[0].nodeValue);//彈出150萬(wàn)  
  35. //alert(xmlDoc.getElementsByTagName("address")[0].childNodes[0].childNodes[1].childNodes[0].nodeValue);//彈出一室三居  
  36.   
  37. //層層遍歷解析childNodes[1]  
  38. //alert(xmlDoc.childNodes[1].childNodes[1].childNodes[0].childNodes[0].nodeValue);//彈出200萬(wàn)  
  39. //alert(xmlDoc.childNodes[1].childNodes[0].childNodes[0].childNodes[0].nodeValue);//彈出150萬(wàn)  
  40. //alert(xmlDoc.childNodes[1].childNodes[0].childNodes[1].childNodes[0].nodeValue);//彈出一室三居  
  41.   
  42.   
  43. //還可以用item(i)進(jìn)行遍歷  
  44. //var nodes=xmlDoc.documentElement.childNodes;  
  45. //alert(nodes.item(0).childNodes.item(0).childNodes.item(0).text); //彈出150萬(wàn)  
  46. //alert(nodes.item(0).childNodes.item(1).childNodes.item(0).text); //彈出一室三居  
  47.   
  48. //火狐解析xml文檔  
  49. //火狐瀏覽器和ie解析xml不一樣節(jié)點(diǎn)的值用textContent。  
  50. //并且他會(huì)在有的層次child節(jié)點(diǎn)前后都加上"\n"換行符。(這個(gè)搞不清楚為什么,用firebug調(diào)試的時(shí)候就是這個(gè)樣子,所以寫(xiě)過(guò)的代碼最好測(cè)試一下,換個(gè)環(huán)境就不對(duì)了)  
  51. //也就是說(shuō)第1個(gè)節(jié)點(diǎn)是"\n",第2個(gè)節(jié)點(diǎn)才是真正的第一個(gè)節(jié)點(diǎn)。  
  52. //第3個(gè)節(jié)點(diǎn)是"\n",第4個(gè)節(jié)點(diǎn)才是真正的第二個(gè)節(jié)點(diǎn)。  
  53. //層層獲取解析childNodes[0]  
  54. //alert(xmlDoc.childNodes[0].childNodes[1].childNodes[1].textContent);//彈出150萬(wàn)  
  55. //alert(xmlDoc.childNodes[0].childNodes[1].childNodes[3].textContent);//彈出一室三居  
  56.   
  57. //直接獲取節(jié)點(diǎn)名解析getElementsByTagName("address")  
  58. //alert(xmlDoc.getElementsByTagName("address")[0].textContent);//彈出150萬(wàn) 一室三居 200萬(wàn)  300萬(wàn)  
  59. //alert(xmlDoc.getElementsByTagName("address")[0].childNodes[1].textContent);//彈出150萬(wàn) 一室三居  
  60. //alert(xmlDoc.getElementsByTagName("address")[0].childNodes[1].childNodes[1].textContent);//彈出150萬(wàn)  
  61. //alert(xmlDoc.getElementsByTagName("address")[0].childNodes[1].childNodes[3].textContent);//彈出一室三居  
  62. //alert(xmlDoc.getElementsByTagName("address")[0].childNodes[3].textContent);//彈出200萬(wàn)   
  63.   
  64.   
  65. //火狐也可以用item(1)函數(shù)遍歷,注意也是有的層次節(jié)點(diǎn)前后都加了節(jié)點(diǎn)"\n"。  
  66. //第一個(gè)節(jié)點(diǎn)是item(1),第二個(gè)節(jié)點(diǎn)是item(3),第三個(gè)節(jié)點(diǎn)是item(5)  
  67. //item(1)函數(shù)遍歷解析  
  68. //var nodes=xmlDoc.documentElement.childNodes;  
  69. //alert(nodes.item(1).textContent); //彈出150萬(wàn)  一室三居  
  70. //alert(nodes.item(1).childNodes.item(1).textContent); //彈出150萬(wàn)    
  71. //alert(nodes.item(1).childNodes.item(3).textContent); //一室三居   
  72.   
  73.   
  74.   
  75.   
  76.   
  77.   
  78.   
  79.   
  80. //解析xml字符串/////////////////////////////////////////////////////////////////////////  
  81. var str="<car>"+  
  82. "<brand><price>50萬(wàn)</price><pattern>A6</pattern></brand>"+  
  83. "<brand><price>65萬(wàn)</price><pattern>A8</pattern></brand>"+  
  84. "<brand><price>17萬(wàn)</price></brand>"+  
  85. "</car>";  
  86.   
  87. //跨瀏覽器,ie和火狐解析xml使用的解析器是不一樣的。  
  88. var xmlStrDoc=null;  
  89. if (window.DOMParser){// Mozilla Explorer  
  90.   parser=new DOMParser();  
  91.   xmlStrDoc=parser.parseFromString(str,"text/xml");  
  92. }else{// Internet Explorer  
  93.   xmlStrDoc=new ActiveXObject("Microsoft.XMLDOM");  
  94.   xmlStrDoc.async="false";  
  95.   xmlStrDoc.loadXML(str);  
  96. }  
  97.   
  98.   
  99. //ie解析xml字符串  
  100. //alert(xmlStrDoc.getElementsByTagName("car")[0].childNodes[0].childNodes[0].childNodes[0].nodeValue);//彈出50萬(wàn)  
  101. //alert(xmlStrDoc.getElementsByTagName("car")[0].childNodes[0].childNodes[1].childNodes[0].nodeValue);//彈出A6  
  102.   
  103. //還可以用item(i)進(jìn)行遍歷  
  104. //var strNodes=xmlStrDoc.documentElement.childNodes;  
  105. //alert(strNodes.item(0).childNodes.item(0).childNodes.item(0).text); //彈出50萬(wàn)  
  106. //alert(strNodes.item(0).childNodes.item(1).childNodes.item(0).text); //彈出A6  
  107.   
  108.   
  109.   
  110. //火狐解析xml字符串  
  111. //火狐瀏覽器和ie解析xml不一樣節(jié)點(diǎn)的值用textContent。  
  112. //并且他會(huì)在有的層次child節(jié)點(diǎn)前后都加上"\n"換行符。  
  113. //也就是說(shuō)第1個(gè)節(jié)點(diǎn)是"\n",第2個(gè)節(jié)點(diǎn)才是真正的第一個(gè)節(jié)點(diǎn)。  
  114. //第3個(gè)節(jié)點(diǎn)是"\n",第4個(gè)節(jié)點(diǎn)才是真正的第二個(gè)節(jié)點(diǎn)。  
  115. //alert(xmlStrDoc.childNodes[0].childNodes[1].textContent);//彈出65萬(wàn)  A8  
  116. //alert(xmlStrDoc.childNodes[0].childNodes[1].childNodes[1].textContent);//A8  
  117. //alert(xmlStrDoc.childNodes[0].childNodes[1].childNodes[0].textContent);//彈出65萬(wàn)  
  118.   
  119. //火狐也可以用item(1)函數(shù)遍歷,注意也是有的層次節(jié)點(diǎn)前后都加了節(jié)點(diǎn)"\n"。  
  120. //第一個(gè)節(jié)點(diǎn)是item(1),第二個(gè)節(jié)點(diǎn)是item(3),第三個(gè)節(jié)點(diǎn)是item(5)  
  121. //var nodes=xmlStrDoc.documentElement.childNodes;  
  122. //alert(nodes.item(1).textContent); //彈出65萬(wàn)  A8  
  123. //alert(nodes.item(1).childNodes.item(0).textContent); //彈出65萬(wàn)   
  124. //alert(nodes.item(1).childNodes.item(1).textContent); //彈出A8   
  125.   
  126. </script>  



其中xml每個(gè)節(jié)點(diǎn)所在層次是最煩人的問(wèn)題,只能一次次去試,只要出來(lái)一個(gè)正確的,

就很好確定節(jié)點(diǎn)的層次關(guān)系了,或者debug一下。

感覺(jué)這方面json還是更好閱讀和理解。這個(gè)解析太費(fèi)勁了!

 

 

文檔house.xml內(nèi)容如下:

  1. <?xml version="1.0" encoding="utf-8" ?>     
  2. <address>    
  3.    <city name="北京">    
  4.        <price>150萬(wàn)</price>    
  5.        <type>一室三居</type>    
  6.    </city>    
  7.    <city name="上海">    
  8.        <price>200萬(wàn) </price>    
  9.    </city>    
  10.    <city name="杭州">    
  11.        <price>230萬(wàn)</price>    
  12.    </city>    
  13.    <city name="南京"></city>    
  14. </address>    



本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶(hù)發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
XML DOM介紹
用QTP調(diào)用外部vbs讀寫(xiě)XML的例子
二級(jí)聯(lián)動(dòng)JS+XML
VB.NET中操作xml文件
xml增刪改查
主題:JavaScript解析XML知識(shí)點(diǎn)總結(jié)
更多類(lèi)似文章 >>
生活服務(wù)
熱點(diǎn)新聞
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服