自己写了一个XML,想用它在jsp里生成动态树。哪位大人给小弟指点一下。现有100分全给了(在线等)

oyster01 2005-04-22 11:35:25
我的xml文件如下我只给出了一部分因为原文件比较长,大人们只要告诉我方法就可以了。
<?xml version="1.0" encoding="GB2312"?>
<!-- edited with XML Spy v3.0 NT by guo (212) -->
<os概念树>
<Topic ID="软件/操作系统">
<name>操作系统</name>
<SuperTopic>软件</SuperTopic>
<comment>C</comment>
<SubTopic>操作系统引论</SubTopic>

</Topic>
<Topic ID="软件/操作系统/操作系统引论">
<name>操作系统引论</name>
<SuperTopic>软件/操作系统</SuperTopic>
<SuperTopic>软件</SuperTopic>
<SubTopic>os的定义
<背景知识 name="软硬件的相关知识"/>
</SubTopic>
<SubTopic>os的地位
<背景知识 name="os的定义"/>
</SubTopic>
<SubTopic>os的特征
<组成 name="并发性"/>
<组成 name="共享性"/>
<组成 name="异步性"/>
</SubTopic>
<SubTopic>os的功能
<组成 name="进程管理"/>
<组成 name="存储管理"/>
<组成 name="文件管理"/>
<组成 name="作业管理"/>
</SubTopic>
<SubTopic>os的类型</SubTopic>
<SubTopic>os提共的用户界面
<组成 name="命令界面"/>
<组成 name="图形界面"/>
<组成 name="系统调用界面"/>
</SubTopic>
</Topic>
<Topic ID="软件/操作系统/操作系统引论/os的类型">
<name>os的类型</name>
<SuperTopic>软件/操作系统/os的类型</SuperTopic>
<SuperTopic>软件/操作系统</SuperTopic>
<SuperTopic>软件</SuperTopic>
<comment>引论描述结束</comment>
<SubTopic>批处理系统
<背景知识 name="单道"/>
<背景知识 name="多道程序设计"/>
</SubTopic>
<SubTopic>分时系统
<背景知识 name="分时概念"/>
<背景知识 name="分时特点"/>
</SubTopic>
<SubTopic>实时系统
<背景知识 name="实时概念"/>
<背景知识 name="实时特点"/>
</SubTopic>
<SubTopic>网络操作系统</SubTopic>
<SubTopic>分布式操作系统</SubTopic>
</Topic>
</os概念树>

我刚开始学jsp,所以不太明白jsp是怎样解析和读取xml文件的。所以希望各位大人能给小弟指点迷经。如果肯给代码的话请发到abc-0976ur@163.com。万分感谢!!
...全文
147 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
飞行的兔子 2005-04-22
  • 打赏
  • 举报
回复
到blog.csdn.net/beyond_xiruo上去看看!
jihanzhong 2005-04-22
  • 打赏
  • 举报
回复
Java更新XML的四种常用方法简介
出处:CSDN
责任编辑:ljx

http://www.pconline.com.cn/pcedu/empolder/gj/java/0408/441419.html
yyzh 2005-04-22
  • 打赏
  • 举报
回复
楼主你把上面这些代码拷贝下去运行一下,保证你半个小时之内研究明白,注意这几个地方

<script language="javascript" for="menuxml" event="onreadystatechange">

OpenElement 这个函数是JavaScript里面自己写的函数 不是微软XML的方法

出效果的代码 在 menu.innerHTML 这几处

我觉得这个是最简单的XML处理方法了
yyzh 2005-04-22
  • 打赏
  • 举报
回复
<script language="javascript">
var xnode = new Array();
var x = 0;

function SelectNodes(ev, tn)
{
var childs = ev.childNodes;
if (childs==0) return 0;
for (var i=0;i<childs.length;i++)
{
if (childs[i].tagName==tn) return 1;
}
return 0;
}

function SelectSingleNode(ev, tn)
{
var childs = ev.childNodes;
if (childs==0) return null;
for (var i=0;i<childs.length;i++)
{
if (childs[i].tagName==tn) return childs[i];
}
return null;
}

function OpenElement(e_name, e_id)
{
var ev;
ev = document.getElementsByTagName(e_name);
for (var i=0;i<ev.length;i++)
{
if (String(ev[i].id).toLowerCase()==String(e_id).toLowerCase())
return ev[i];
}
var nev = document.createElement(e_name);
nev.id = e_id;
document.body.insertAdjacentElement("beforeEnd", nev);
return nev;
}

function OpenMenu(nodes)
{
var ele = event.srcElement;
var parentMenu = new Object();
if (ele.tagName=="xml")
{
parentMenu = OpenElement("div", "xmenu");
}
else if (ele.tagName=="IMG" || ele.tagName=="A")
{
parentMenu = ele.parentNode;
}
else if (ele.tagName=="DIV")
{
parentMenu = ele;
}
else
{
return;
}
if (SelectNodes(parentMenu, "DIV"))
{
//alert("123");
var childs = parentMenu.childNodes;
var display = "";
for (var i=0;i<childs.length;i++)
{
if (childs[i].tagName=="DIV")
{
display = childs[i].style.display;
childs[i].style.display = (display=="none")?"":"none";
}
}
var img = SelectSingleNode(parentMenu, "IMG");
if (img==null) return;
img.src = (display=="none")?"menu1.gif":"menu0.gif";
}
else
{
var childs = nodes.childNodes;
if (childs.length==0) return;
var left = parseInt(parentMenu.style.left);
if (isNaN(left)) left = 0;
for (var i=0;i<childs.length;i++)
{
xnode[x] = childs[i];
var menu = OpenElement("div", "menu" + x);
parentMenu.insertAdjacentElement("beforeEnd", menu);
menu.style.left = left + 10;
menu.style.position = "relative";
menu.style.display = "";
if (childs[i].hasChildNodes())
{
menu.innerHTML = '<img src="menu0.gif" onclick="OpenMenu(xnode[' + x + '])" style="cursor:hand" /> <a href="javascript:" onclick="OpenMenu(xnode[' + x + '])">' + childs[i].getAttribute("name") + '</a>';
}
else
{
menu.innerHTML = '<img src="menu1.gif" /> <a href="javascript:">' + childs[i].getAttribute("name") + '</a>';
}
x++;
}
var img = SelectSingleNode(parentMenu, "IMG");
if (img==null) return;
img.src = "menu1.gif";
}
}
</script>

<script language="javascript" for="menuxml" event="onreadystatechange">
var xmenu = OpenElement("div", "xmenu");
var state = this.readyState;
switch (state)
{
case "complete":
xmenu.innerHTML = "";
if (this.parseError.errorCode)
{
alert("HOHO:" + this.parseError.reason);
}
else
{
var root = this.documentElement;
OpenMenu(root);
}
break;
default:
xmenu.innerHTML = state;
break;
}
</script>
</head>

<body>
<xml id="menuxml" src="xmenu.xml"></xml>
<div id="hint"></div>
</body>

</html>
-----------------------------------------------------------------------------
<?xml version="1.0"?>
<menu>
<menu name="User Manager 0">
<menu name="Profile Manager" />
<menu name="Password Manager" />
<menu name="User Liste" />
<menu name="User Manager 1">
<menu name="Profile Manager" />
<menu name="Password Manager" />
<menu name="User Liste" />
<menu name="User Manager 2">
<menu name="User Liste" />
<menu name="User Liste" />
</menu>
</menu>
</menu>
<menu name="User Manager">
<menu name="Profile Manager" />
<menu name="Password Manager" />
<menu name="User Liste" />
</menu>
<menu name="User Manager">
<menu name="Profile Manager" />
<menu name="Password Manager" />
<menu name="User Liste" />
</menu>
<menu name="User Manager">
<menu name="Profile Manager" />
<menu name="Password Manager" />
<menu name="User Liste" />
</menu>
<menu name="User Manager">
<menu name="Profile Manager" />
<menu name="Password Manager" />
<menu name="User Liste" />
</menu>
<menu name="User Manager">
<menu name="Profile Manager" />
<menu name="Password Manager" />
<menu name="User Liste" />
</menu>
</menu>
oyster01 2005-04-22
  • 打赏
  • 举报
回复
beyond_xiruo的文我看过了不过看不大懂,里面涉及的一些知识点我不大明白。所以才到这里来提问的呀。

67,513

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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