DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript綜合知識 >> Javascript Ajax異步讀取RSS文檔具體實現
Javascript Ajax異步讀取RSS文檔具體實現
編輯:JavaScript綜合知識     

 這篇文章主要介紹了Javascript Ajax異步讀取RSS文檔具體實現,有需要的朋友可以參考一下

RSS 是一種基於 XML的文件標准,通過符合 RSS 規范的 XML文件可以簡單實現網站之間的內容共享。Ajax 是Asynchronous JavaScript and XML的縮寫。通過 Ajax 技術可以經由超文本傳輸協議(Http) 向一個服務器發出請求並且在等待該響應時繼續處理另外的數據。通過 Ajax 技術可以很容易實現讀取遠程 XML文件,因此,可以使用 Ajax技術實現遠程訪問依據 RSS 標准生成的摘要信息,甚至我們可以自己寫一個 RSS 閱讀器。           Ajax 並不是一門新的語言或技術, 它實際上是幾項技術按一定的方式組合在一起。共同在協作中發揮各自的作用, 它包括:使用XHTML 和CSS 標准化呈現; 使用DOM 實現動態顯示和交互; 使用XML 和XSLT 進行數據交換與處理; 使用XMLHttpRequest進行異步數據讀取; 最後用 JavaScript 綁定和處理所有數據。好了,對於理論就不在多說了,下面我們直接看代碼吧。           創建XMLHttpRequest對象並將請求發送到服務器:  代碼如下: function createXHR(url){      if(window.XMLHttpRequest){          xmlHttp = new XMLHttpRequest();      }else{          xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");      }      xmlHttp.open("post",url,"false");      xmlHttp.onreadystatechange = getResponse;     xmlHttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");      xmlHttp.send(null);  }     通過DOM操作對Rss文檔進行遍歷,得到需要的值:    代碼如下: function readDoc(doc){      root = doc.getElementsByTagName("channel")[0];      docTitle = root.getElementsByTagName("title")[0];      docLink = root.getElementsByTagName("link")[0];      docDescription = root.getElementsByTagName("description")[0];      items = root.getElementsByTagName("item");      for(var i=0;i<items.length;i++){          itemTitle = items[i].getElementsByTagName("title")[0];          itemLink = items[i].getElementsByTagName("link")[0];          itemDescription = items[i].getElementsByTagName("description")[0];          //itemPubDate = items[i].getElementsByTagName("pubDate")[0];          document.getElementById("rssTitle").innerHTML = docTitle.firstChild.nodeValue;          temp = "</h1><h2><a href=""+itemLink.firstChild.nodeValue+"" target="_blank">"+itemTitle.firstChild.nodeValue+"</a></h2>"+"<p>"+itemDescription.firstChild.nodeValue+"</p><hr/>";          document.getElementById("readRss").style.display = "none";          document.getElementById("printRss").getElementsByTagName("span")[0].style.display = "none";          document.getElementById("printRss").innerHTML = document.getElementById("printRss").innerHTML + temp;      }  }     調用createXHR(url)函數,傳入參數,向服務器發送求:   代碼如下: createXHR("http://www.apple.com.cn/hotnews/rss/hotnews.rss");     得到響應:    代碼如下: function getResponse(){     if(xmlHttp.readyState == 4){               if(xmlHttp.status == 200){               rssDoc = xmlHttp.responseXML;              readDoc(rssDoc);//調用readDoc()函數          }else{              document.getElementById("rssTitle").innerHTML = "讀取異常!";              //alert(xmlHttp.status);          }      }  }
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved