手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >JavaScript操作XML 使用百度RSS作为新闻源示例
JavaScript操作XML 使用百度RSS作为新闻源示例
摘要:js操作xml源,作为页面的动态新闻参考JS源码如下(存为rss.js文件):复制代码代码如下:varmain=document.getEl...

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></div>

<div></div>

<div></div>

<div></div>

<div></div>

<div></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;

}

【JavaScript操作XML 使用百度RSS作为新闻源示例】相关文章:

javascript中FOREACH数组方法使用示例

关于JavaScript作用域你想知道的一切

JavaScript中反正弦函数Math.asin()的使用简介

JavaScript AOP编程实例

JavaScript中使用自然对数ln的方法

JavaScript函数使用的基本教程

JavaScript中fixed()方法的使用简介

JavaScript中isPrototypeOf函数作用和使用实例

JavaScript中的异常处理方法介绍

JavaScript中String.match()方法的使用详解

精品推荐
分类导航