JavaScript操作XML 使用百度RSS作為新聞源樣本

來源:互聯網
上載者:User

js操作xml源,作為頁面的動態新聞
參考JS源碼如下(存為rss.js檔案): 複製代碼 代碼如下:var main = document.getElementById("content").getElementsByTagName("DIV");
/*
* 目前的目錄下面有一個名為xml的子檔案夾,下面引用的源儲存在目錄下。
* 下面每一行的冒號前面是檔案名稱,後面是xml源地址(可以從源址下載得到xml檔案,下載後儲存為對應檔案名稱)
* 可以在下面的地址上單擊右鍵,選擇目標另存新檔,下載後得到的是txt檔案,更改副檔名為xml即可
* movie:"http://news.baidu.com/n?cmd=1&class=film&tn=rss"
* woman:"http://news.baidu.com/n?cmd=1&class=healthnews&tn=rss"
* house:"http://news.baidu.com/n?cmd=1&class=housenews&tn=rss"
* car:"http://news.baidu.com/n?cmd=1&class=autonews&tn=rss"
* sport:"http://news.baidu.com/n?cmd=1&class=sportnews&tn=rss"
* edu:"http://news.baidu.com/n?cmd=1&class=edunews&tn=rss"
*/
var RssSource = {
movie: "xml/movie.xml",
woman: "xml/woman.xml",
house: "xml/house.xml",
car: "xml/car.xml",
sport: "xml/sport.xml",
edu: "xml/edu.xml"
}
function Init() {
LoadXml(RssSource.movie, main[0]);
LoadXml(RssSource.woman, main[1]);
LoadXml(RssSource.house, main[2]);
LoadXml(RssSource.car, main[3]);
LoadXml(RssSource.sport, main[4]);
LoadXml(RssSource.edu, main[5]);
}
function LoadXml(url, target) {
var xml = null;
var isIE = true;
if (window.ActiveXObject) //IF IE
{
xml = new ActiveXObject("Microsoft.XMLDOM");
isIE = true;
} else if (document.implementation.createDocument) //IF FF
{
xml = document.implementation.createDocument("", "", null);
isIE = false;
}
xml.async = false;
xml.load(url);
//擷取XML文檔根節點
var root = xml.documentElement;
//擷取RSS的XML源中的item節點
var items = root.getElementsByTagName("item");
//建立DOm對象 ——RSS標題
var head = document.createElement("dt");
head.setAttribute("style", "background-color:#ccc;cursor:pointer;");
if (isIE) { //IE時操作
head.innerHTML = "<b>" + (root.getElementsByTagName("title")[0].text).substring(2, 6) + "</b> <sub>" + root.getElementsByTagName("pubDate")[0].text + "</sub>";
target.appendChild(head);
//建立DOm對象 ——RSS列表
var ul = document.createElement("ul");
//把列表添加到DIV容器中
target.appendChild(ul);
//迴圈輸出每天新聞到li中,其中items.length是新聞條數
for (i = 0; i < items.length; i++) {
//建立DOM對象li,存放新聞
var li = document.createElement("li");
//建立DOM超連結對象
var lk = document.createElement("a");
//時間
//超連結的title屬性,同時用於儲存新聞文本
lk.title = items[i].selectSingleNode("title").text;
//設定超連結的href屬性
lk.href = items[i].selectSingleNode("link").text;
//超連結顯示的文本 , 若長於15個字元,則截取,然後加上...
lk.innerHTML = lk.title.length > 18 ? lk.title.substring(0, 16) + "....": lk.title;
//lk.innerText = lk.title;
//把li添加到ul中
ul.appendChild(li);
//把超連結添加到li中
li.appendChild(lk);
}
} else { //非IE時操作
head.innerHTML = "<b>" + (root.getElementsByTagName("title")[0].textContent).substring(2, 6) + "</b> <sub>" + root.getElementsByTagName("pubDate")[0].textContent + "</sub>";
target.appendChild(head);
//建立DOm對象 ——RSS列表
var ul = document.createElement("ul");
//把列表添加到DIV容器中
target.appendChild(ul);
//迴圈輸出每天新聞到li中,其中items.length是新聞條數
for (i = 0; i < items.length; i++) {
//建立DOM對象li,存放新聞
var li = document.createElement("li");
//建立DOM超連結對象
var lk = document.createElement("a");
//時間
//超連結的title屬性,同時用於儲存新聞文本
lk.title = items[i].getElementsByTagName("title")[0].textContent;
//設定超連結的href屬性
lk.href = items[i].getElementsByTagName("link")[0].textContent;
//超連結顯示的文本 , 若長於15個字元,則截取,然後加上...
lk.innerHTML = lk.title.length > 18 ? lk.title.substring(0, 16) + "....": lk.title;
//lk.innerText = lk.title;
//把li添加到ul中
ul.appendChild(li);
//把超連結添加到li中
li.appendChild(lk);
}
}
}

顯示頁面參考源碼(存為htm頁面) 複製代碼 代碼如下:<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<link type="text/css" rel="stylesheet" href="index.css">
<base target="_blank">
</head>
<body onload="Init()">
<div id="pagebody">
<div id="header">
<div id="banner"></div>
</div>
<div id="content">
<div class="left"></div>
<div class="right"></div>
<div class="left"></div>
<div class="right"></div>
<div class="left"></div>
<div class="right"></div>
</div>
</div>
</body>
</html>
<script type="text/javascript" src="rss.js"></script>

CSS源碼(存為index.css ) 複製代碼 代碼如下:a:link,a:visited,a:active {
text-decoration:none;
}
a:hover {
text-decoration:underline;
}
#pagebody {
margin:0 auto;
width:800px;
height:1200px;
border-left:dotted 1px gray;
border-right:dotted 1px gray;
background-color:#eee;
}
#header {
height:200px;
}
#banner {
height:160px;
background-color:#fff;
}
#content div {
width:380px;
height:270px;
border:solid 1px gray;
overflow:hidden;
background-color:#fff;
}
#content div ul li {
list-style-image:url(list.gif);
}
.left {
float:left;
margin-top:10px;
margin-left:10px;
}
.right {
float:right;
margin-top:10px;
margin-right:10px;
}

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.