JavaScript操作XML 使用百度RSS作为新闻源示例_javascript技巧

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

时间: 2024-08-31 04:13:36

JavaScript操作XML 使用百度RSS作为新闻源示例_javascript技巧的相关文章

JavaScript操作XML/HTML比较常用的对象属性集锦_javascript技巧

节点对象属性 childNodes-返回节点到子节点的节点列表 firstChild-返回节点的首个子节点. lastChild-返回节点的最后一个子节点. nextSibling-返回节点之后紧跟的同级节点. nodeName-返回节点的名字,根据其类型. nodeType-返回节点的类型. nodeValue-设置或返回节点的值,根据其类型. ownerDocument-返回节点的根元素(document对象). parentNode-返回节点的父节点. previousSibling-返回

javascript读取Xml文件做一个二级联动菜单示例_javascript技巧

复制代码 代码如下: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>menu2level.html</title> <meta http-equiv="content-type" content="text/html; charset=UTF-8"> &

JavaScript操作XML实例代码(获取新闻标题并分页,并分页)_javascript技巧

具体内容我没有做测试.仅供参考 代码 复制代码 代码如下: <?xml version="1.0" encoding="gb2312"?> <NEWS> <New id="1" name="测试新闻1" time="2010-2-18"> <NBody>新闻测试1新闻测试1</NBody> </New> <New id="

javascript解析xml实现省市县三级联动的方法_javascript技巧

本文实例讲述了javascript解析xml实现省市县三级联动的方法.分享给大家供大家参考.具体实现方法如下: (该方法适用于任何常用浏览器) <body> <div> <span> <select id="sheng" style="width: 100px"></select> </span> <span> <select id="shi" style=

静态页面下用javascript操作ACCESS数据库(读增改删)的代码_javascript技巧

静态页面读取ACCESS数据库.htm 复制代码 代码如下: <script language="javascript">   //用 JavaScript 写服务器端连接数据库的代码示例   var conn = new ActiveXObject("ADODB.Connection");   conn.Open("DBQ=E:\\a.mdb;DRIVER={Microsoft Access Driver (*.mdb)};"); 

javascript读写XML实现广告轮换(兼容IE、FF)_javascript技巧

xml结构如下 复制代码 代码如下: <ad><tupian>http://www.seehaha.com/images/060901-150.100.2.gif</tupian><tupian>http://www.seehaha.com/xml/061009-300.100.jpg</tupian><dizhi>http://www.seehaha.com/plan/</dizhi><dizhi>http:

javascript操作table(insertRow,deleteRow,insertCell,deleteCell方法详解)_javascript技巧

insertRow() 方法 定义和用法 insertRow() 方法用于在表格中的指定位置插入一个新行. 语法 tableObject.insertRow(index) 返回值 返回一个 TableRow,表示新插入的行. 说明 该方法创建一个新的 TableRow 对象,表示一个新的 <tr> 标记,并把它插入表中的指定位置. 新行将被插入 index 所在行之前.若 index 等于表中的行数,则新行将被附加到表的末尾. 如果表是空的,则新行将被插入到一个新的 <tbody>

javascript操作cookie方法函数集合第1/2页_javascript技巧

问题: 使得在访问页面的时候能够沿用上次的设置,或者在不同的页面间共享数据.比如用户在访问网站的时候设置了页面字体的大小,那么会希望下次访问的时候仍然能使用同样的设置进行浏览,而不用重复设置. 解决方案: 在用户浏览页面并进行设置时,将这些设置保存在cookie中,下次访问的时候读取cookie中的设置. 参考下面的脚本: 复制代码 代码如下: // utility function to retrieve an expiration data in proper format; functio

javascript中的绑定与解绑函数应用示例_javascript技巧

Mozilla中: addEventListener的使用方式: target.addEventListener(type, listener, useCapture); target: 文档节点.document.window 或 XMLHttpRequest. type: 字符串,事件名称,不含"on",比如"click"."mouseover"."keydown"等. listener :实现了 EventListene