欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

原生javascript實(shí)現(xiàn)解析XML文檔與字符串

 更新時(shí)間:2016年03月01日 08:56:49   投稿:hebedich  
這篇文章主要介紹了javascript解析XML文檔和XML字符串的方法和具體的代碼解析,有需要的小伙伴可以參考下。

之前寫(xiě)過(guò)一篇 《使用jquery解析XML的方法》鏈接是http://www.dbjr.com.cn/article/54842.htm,上篇文章詳細(xì)解釋了jQuery 與字符串互相轉(zhuǎn)換的方法 ,這里著重論述javascript操作xml。

總代碼如下:

var XMLHttp = null;
if (window.XMLHttpRequest) { //現(xiàn)代瀏覽器
  XMLHttp = new XMLHttpRequest();
} else if (window.ActiveXObject) {
  XMLHttp = new ActiveXObject("Microsoft.XMLHTTP"); //IE5/IE6
}
if (XMLHttp !== null) {
  XMLHttp.onreadystatechange = function() {
    if (XMLHttp.readyState === 4) {
      if (XMLHttp.status === 200 || XMLHttp.status === 304) {
        // var XMLDom = XMLHttp.responseXML; //解析XML文檔
        var XMLDoc = XMLHttp.responseText; //解析XML字符串
        var XMLDom = (new DOMParser()).parseFromString(XMLDoc, "text/xml");
        //異步代碼寫(xiě)這里
        console.log(XMLDom);
        console.log("world"); //后出現(xiàn)world
      }
    }
  };
  XMLHttp.open("get", "test1.xml", true);
  XMLHttp.send();
  //非異步代碼寫(xiě)這里
  console.log("hello"); //先出現(xiàn)hello
}

第一步,創(chuàng)建XMLHTTPREQUEST:

var XMLHttp = null;
if (window.XMLHttpRequest) { //現(xiàn)代瀏覽器
  XMLHttp = new XMLHttpRequest();
} else if (window.ActiveXObject) {
  XMLHttp = new ActiveXObject("Microsoft.XMLHTTP"); //IE5/IE6
}

第二步,檢測(cè)ONREADYSTATECHANGE(非異步不需要):

if (XMLHttp !== null) {
  XMLHttp.onreadystatechange = function() {
    if (XMLHttp.readyState === 4) {
      if (XMLHttp.status === 200 || XMLHttp.status === 304) {
        //異步代碼寫(xiě)這里
      }
    }
  };
  XMLHttp.open("get", "test1.xml", true);
  XMLHttp.send();
  //非異步代碼寫(xiě)這里
}

第三步,解析XML文檔或字符串(異步):

XMLHttp.onreadystatechange = function() {
    if (XMLHttp.readyState === 4) {
      if (XMLHttp.status === 200 || XMLHttp.status === 304) {
        // var XMLDom = XMLHttp.responseXML; //解析XML文檔
        var XMLDoc = XMLHttp.responseText; //解析XML字符串
        var XMLDom = (new DOMParser()).parseFromString(XMLDoc, "text/xml");
        //異步代碼寫(xiě)這里
        console.log(XMLDom);
      }
    }
  };
  

第四步,解析XML文檔或字符串(非異步):

if (XMLHttp !== null) {
  // XMLHttp.onreadystatechange = function() {
  //   if (XMLHttp.readyState === 4) {
  //     if (XMLHttp.status === 200 || XMLHttp.status === 304) {}
  //   }
  // };
  XMLHttp.open("get", "test1.xml", false);
  XMLHttp.send();
  //非異步代碼寫(xiě)這里
  // var XMLDom = XMLHttp.responseXML; //解析XML文檔
  var XMLDoc = XMLHttp.responseText; //解析XML字符串
  var XMLDom = (new DOMParser()).parseFromString(XMLDoc, "text/xml");
  //異步代碼寫(xiě)這里
  console.log(XMLDom);
}

相關(guān)文章

最新評(píng)論