欧洲新闻网 | 中国 | 国际 | 社会 | 娱乐 | 时尚 | 民生 | 科技 | 旅游 | 体育 | 财经 | 健康 | 文化 | 艺术 | 人物 | 家居 | 公益 | 视频 | 华人
投稿邮箱:uscntv@outlook.com
主页 > 关注 > 热点 > 正文

JavaScript操纵XML 行使百度RSS作为消息源示例

2017-09-03 12:37  网络整理  ustv

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" href="index.css">
<base target="_blank">
</head>
<body>
<div>
<div>
<div></div>
</div>
<div>
<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 )

  声明:文章大多转自网络,旨在更广泛的传播。本文仅代表作者个人观点,与美国新闻网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。如有稿件内容、版权等问题请联系删除。联系邮箱:uscntv@outlook.com。

上一篇:很全的RSS源地点 但愿对各人有些辅佐哦
下一篇:XML与DataSet的彼此转换类

热点新闻

重要通知

服务之窗

关于我们| 联系我们| 广告服务| 供稿服务| 法律声明| 招聘信息| 网站地图

本网站所刊载信息,不代表美国新闻网的立场和观点。 刊用本网站稿件,务经书面授权。

美国新闻网由欧洲华文电视台美国站主办 www.uscntv.com

[部分稿件来源于网络,如有侵权请及时联系我们] [邮箱:uscntv@outlook.com]