使用js实现html加载xml内容(本地电脑使用)

JavaScript022

使用js实现html加载xml内容(本地电脑使用),第1张

JS中有原生函数,支持解析xml字符串或者文件。

(new DOMParser()).parseFromString(xxxxx)

这个代码可以解析XML字符串,为对象。

<html>

<body>

<script type="text/javascript">

try //Internet Explorer

  {

  xmlDoc=new ActiveXObject("Microsoft.XMLDOM")

  }

catch(e)

  {

  try //Firefox, Mozilla, Opera, Chrome, etc.

    {

    xmlDoc=document.implementation.createDocument("","",null)

    }

  catch(e) {alert(e.message)}

  }

try 

  {

  xmlDoc.async=false

  xmlDoc.load("books.xml")

  document.write("xmlDoc is loaded, ready for use")

  }

catch(e) {alert(e.message)}

</script>

</body>

</html>

上面这段代码可以解析一个XML文件。

具体的可参考下面教程,或者小乐阅读(Chrome浏览器中的RSS阅读器)中的源代码

http://www.w3school.com.cn/xmldom/dom_parser.asp

JS]利用js将读取到的xml文件中的数据显示到html文档上

script type="text/javascript" language="javascript">

var xmlDoc = checkXMLDocObj('../openClass.xml')//读取到xml文件中的数据

var a = document.getElementsByTagName("a")//获取所有的A标签

$(document).ready(function () {

var nodes

if($.browser.msie){ // 注意各个浏览器之间的区别

nodes = xmlDoc.getElementsByTagName('collage')[0].childNodes//读取XML文件中需要显示的数据

}

else if (isFirefox=navigator.userAgent.indexOf("Firefox")>0){

nodes = xmlDoc.getElementsByTagName('collage')[0].children//读取XML文件中需要显示的数据

}

else{

nodes = xmlDoc.getElementsByTagName('resource')

}

for (var i = 0i <a.lengthi++) {

if (a[i].parentNode.nodeName == "SPAN") {

for (var j = 0j <nodes.lengthj++) {

var resource = nodes[j]

var url = resource.getAttribute('url')

var href=$(a[i]).attr("href")

if (href == url) {

var count = resource.getAttribute('click')

var span = document.createElement("div")

var str = document.createTextNode("点击率:" + count)

span.appendChild(str)

var div = a[i].parentNode.parentNode

div.appendChild(span)

break

}

}

}

}

})

$(function(){ //通过get请求,将点击率增加

$(a).mousedown(function(){

var href = $(this).attr("href")

$.get("../receive.ashx",{url:href,rd:Math.random()}, function (msg) {

})

})

})

</script>

1. JS加载XML文件

步骤一般为(1),建立 XML DOM 对象;(2),设置加载方式,异步(推荐)或同步; (3)提供XML文件URL然后调用 load 方法;大致如下:

var xmlFileName="xxFile.xml"

var xmlDoc=''

if (window.ActiveXObject){ // IE

var activeXNameList=new Array("MSXML2.DOMDocument.6.0","MSXML2.DOMDocument.5.0","MSXML2.DOMDocument.4.0","MSXML2.DOMDocument.3.0","MSXML2.DOMDocument","Microsoft.XMLDOM","MSXML.DOMDocument")

for(var h=0h

{

try{

xmlDoc=new ActiveXObject(activeXNameList[h])

}catch(e){

continue

}

if(xmlDoc) break

}

}else if(document.implementation &&document.implementation.createDocument){ //非 IE

xmlDoc=document.implementation.createDocument("","",null)

}else{

alert('can not create XML DOM object, update your browser please...')

}

xmlDoc.async=false//同步,防止后面程序处理时遇到文件还没加载完成出现的错误,故同步等XML文件加载完再做后面处理

xmlDoc.load(xmlFileName)//加载XML

2. JS读取XML文件节点

在加载XML文件之后就是读取XML文件的节点了,可以使用 DOM 相应的方法,对 MS IE 其它浏览器的读法相近,例如:

例如下的XML文件结构:

shenzhen

shenzhenNBA

man

shenzhen

xiaoming

woman

zhangsan

man

//JS读取 XML 文件中的 area 节点的方式如下:

var nodeList= xmlDoc.documentElement.getElementsByTagName("area"); // IE

for(var i=0i

//...遍历操作...

}

var nodeList=xmlDoc.getElementsByTagName("area")// 非IE

for(var i=0i

//...遍历操作...

}

还有部分读取节点的方法:

//MS IE

node.text //读取node节点的文本值

node.childNodes[i].text //读取 node 下的第 i 个[直接下一级]子节点的文本

node.getAttribute("attributeName") //读取 node 节点的属性名称为 attributeName 的属性值

//还有其他的方法等, 可以网上搜索