Dom解析XML动态绘制表格.

luozhangwen 2010-10-29 10:46:00

<html>
<script>
function DomUtil(){}

DomUtil.initDomDoc = function()
{
var signatures = ["Msxml2.DOMDocument.5.0","Msxml2.DOMDocument.4.0","Msxml2.DOMDocument.3.0","Msxml2.DOMDocument","MicroSoft.XmlDom"];
for(var i=0;i<signatures.length;i++)
{
try
{
var domDoc = new ActiveXObject(signatures[i]);
if(domDoc!=null)
{
return domDoc;
}
}
catch(e)
{
alert("Dom初始化失败!")
}
}
}
//根据文件的相对路径的文件名来创建xmlDoc
DomUtil.loadXmlForPath = function(path)
{
var domDoc = DomUtil.initDomDoc();
domDoc.async = false;
domDoc.load(path);
return domDoc;
}
//根据XML格式个字符串来创建xmlDoc
DomUtil.loadXmlForString = function(str)
{
var domDoc = DomUtil.initDomDoc();
domDoc.async = false;
domDoc.loadXML(str);
return domDoc;
}

var xmlDom; //全局的xmlDom对象

//页面初始化的时候加载xml
function load()
{
xmlDom = DomUtil.loadXmlForPath("class.xml");
//得到XML的根元素
var rootElement = xmlDom.documentElement;

// var root = DomUtil.loadXmlForString(rootElement.xml);
$("xmlStr").innerText = rootElement.xml;
//alert(rootElement.xml);
display();
}

function display()
{
var table = document.createElement("table");

table.setAttribute("border",1);

$("tableXml").appendChild(table);

var tHead = table.createTHead();
tHead.style.background = "#12c4dd";

var headerRow =tHead.insertRow(0); //创建头插入第一行

headerRow.insertCell(0).appendChild(document.createTextNode("stuName"));
headerRow.insertCell(1).appendChild(document.createTextNode("stuAge"));
headerRow.insertCell(2).appendChild(document.createTextNode("stuNo"));

var students= xmlDom.getElementsByTagName("student"); //根据标签的名字获得所有的student
// var students = rootElement.childNodes;

for(var i = 0; i < students.length; i++)
{
var tableRow = table.insertRow(i+1); //往table里面插入行(Row)

var stuAtts = students[i].childNodes; //获得所有student的子节点
for(var j = 0;j < stuAtts.length; j++)
{
var stuAtt = stuAtts[j].childNodes[0].nodeValue;

tableRow.insertCell(j).appendChild(document.createTextNode(stuAtt));

}
var stuNo = students[i].attributes[0].value; //获得学号

tableRow.insertCell(stuAtts.length).appendChild(document.createTextNode(stuNo));
}
}

...全文
80 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
weizhuo1989 2010-10-29
  • 打赏
  • 举报
回复
luozhangwen 2010-10-29
  • 打赏
  • 举报
回复

function $(varId)
{
return document.getElementById(varId);
}
</script>

<body onload="load();">
<div id="tableXml"></div>
<hr/>
<div id="xmlStr"></div>
</body>
</html>






<class>
<student stuNo="stu01">
<stuName>admin</stuName>
<stuAge> 19 </stuAge>
</student>

<student stuNo="stu02">
<stuName>user</stuName>
<stuAge> 25 </stuAge>
</student>
</class>
目录如下: ==================================== 实例1 HelloWorld 实例10 创建一个窗体 实例100 上传文件 实例11 按扭 实例12 复选框 实例13 复合下拉列表 实例14 下拉列表 实例15 选项卡 实例16 对话框 实例17 文件对话框 实例18 使用HTML语言 实例19 菜单 实例2 java流程控制 实例20 工具栏 实例21 内部窗体 实例22 分割一个面板 实例23 滑动杆 实例24 颜色过滤器 实例25 表格 实例26 基本图形绘制 实例27 绘制波图形 实例28 图片的处理 实例29 绘制指针时钟 实例3 数组数据操作 实例30 三围立方框 实例31 三围立方体 实例32 标准输入输出 实例33 读写文件(字节) 实例34 读写文件(字符操作) 实例35 获取文件信息 实例36 目录操作 实例37 读取随机文件 实例38 操作EXECL文件 实例39 生成PDF文件 实例4 矢量对象操作 实例40 压缩和解压文件 实例41 执行系统命令 实例42 获取计算机名称和IP地址 实例43 一对简单的服务器和客户端 实例44 多线程服务器 实例45 使用SMTP协议发送邮件 实例46 使用SMTP协议接收邮件 实例47 使用JAVAMAIL发送邮件 实例48 使用JAVAMAIL接收邮件 实例49 获取URL文本 实例5 哈希表和枚举器 实例50 一个简单的WEB服务器 实例51 数据报通讯:聊天吧 实例52 使用ODBC连接数据库 实例53 加载JDBC驱动 实例54 使用语句预处理 实例55 可滚动结果集 实例56 数据库元数据 实例57 结果集元数据 实例58 调用存储过程 实例59 事务处理 实例6 类的继承 实例60 继承THREAD 实例62 多线程 实例63 线程组群 实例64 线程间通讯 实例65 线程同步 实例66 线程控制 实例67 线程优先级 实例68 使用DOM解析XML 实例69 使用SAX解析XML 实例7 接口和抽象类 实例70 使用JDOM解析XML 实例71 使用JDOM操作XML 实例72 欢迎进入APPLET世界 实例73 传递参数 实例74 监测鼠标事件 实例75 监测键盘事件 实例76 在APPLET中使用SWING 实例77 应用JAR包 实例78 播放声音 实例79 一个简单的SERVLET 实例8 类的标识和访问控制 实例80 使用SERVLET获取客户表单 实例81 SERVLET读取COOKIE数据 实例82 SERVLET读取SESSION数据 实例83 一个简单的JSP 实例84 JSP处理表单提交 实例85 JSP连接数据库 实例86 JSP使用数据连接池 实例87 JSP+BEAN的应用 实例88 JSP+BEAN连接数据库 实例89 读取属性文件 实例9 异常的捕获和实现自己的异常类 实例90 上传文件 实例91 读取浏览器文件头 实例92 无状态会话EJB 实例93 有状态会话EJB 实例94 容器管理实体EJB 实例95 BEAN自管理实体EJB 实例96 消息驱动BEAN 实例97 简单的STRUTS 实例98 信息表单提交 实例99 连接数据库

23,405

社区成员

发帖
与我相关
我的任务
社区描述
Java 非技术区
社区管理员
  • 非技术区社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧