麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

Javascript Ajax異步讀取RSS文檔具體實現

2019-11-20 21:28:47
字體:
來源:轉載
供稿:網友

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);
        }
    }
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 内地av在线 | 亚洲精品久久久久www | 桥本有菜免费av一区二区三区 | 久久久久久久高清 | 92看片淫黄大片一级 | 九九精品在线观看 | 亚洲午夜国产 | 九色p| 欧美激情性色生活片在线观看 | 亚洲99 | 久久久久久久久久综合 | 国产麻豆交换夫妇 | 成人免费福利网站 | 日韩精品中文字幕在线播放 | japan护士性xxxⅹhd | 国产一区二区三区在线免费观看 | 5xx免费看 | 免费在线观看成人网 | 一级免费视频 | 久久亚洲精品久久国产一区二区 | 久久精品性视频 | 国产噜噜噜噜久久久久久久久 | 欧美性videofree精品 | 国产精品中文在线 | 亚洲一级片免费观看 | 午夜视频免费播放 | 欧美精品一区二区三区在线播放 | 欧美激情性色生活片在线观看 | 国产午夜亚洲精品理论片大丰影院 | 少妇淫片免费一级毛片 | 国产精品av久久久久久久久久 | 九一传媒在线观看 | 精品国产一区二区三区四区在线 | 国产成人精品网站 | 黄色av片三级三级三级免费看 | 高清国产福利 | 国产一国产一级毛片视频在线 | 国产精品视频在线观看免费 | 亚洲aⅴ免费在线观看 | 欧美女人天堂 | 成人污在线 |