网络编程 
首页 > 网络编程 > 浏览文章

Dom遍历XML的一个例子,结果为树状结构

(编辑:jimmy 日期: 2024/11/26 浏览:3 次 )
knowledge.XML文件
复制代码 代码如下:<?xml version="1.0" encoding="gb2312"?> 
<?xml:stylesheet type="text/xsl" href="knowledge.xsl"?> 
<Ebaihe name="Ebaihe" type="gs" id="gs000"> 
<知识管理 name="知识管理" type="rt" id="rt000"> 
  <目录 name="vc++" type="ml" id="ml003"/> 
  <目录 name="asp" type="ml" id="ml001"> 
     <知识 name="什么是ASP 1" type="zs" id="zs001"> 
        <title>什么是ASP</title> 
        <author>cxx</author> 
        <adddate>2001-02-20</adddate> 
        <content>ASP:Active Server Page</content> 
     </知识> 
     <知识 name="什么是ASP 2" type="zs" id="zs002"> 
        <title>什么是ASP</title> 
        <author>cxx</author> 
        <adddate>2001-02-20</adddate> 
        <content>ASP:Active Server Page</content> 
     </知识> 
  </目录> 
  <目录 name="vbs" type="ml" id="ml002"> 
     <知识 name="什么是vbs 1" type="zs" id="zs003"> 
        <title>什么是ASP</title> 
        <author>cxx</author> 
        <adddate>2001-02-20</adddate> 
        <content>ASP:Active Server Page</content> 
     </知识> 
     <知识 name="什么是vbs 2" type="zs" id="zs004"> 
        <title>什么是ASP</title> 
        <author>cxx</author> 
        <adddate>2001-02-20</adddate> 
        <content>ASP:Active Server Page</content> 
     </知识> 
  </目录> 
</知识管理> 
<留言簿 name="留言簿" type="ly" id="ly000"> 
  <单元 name="你好" type="dy" id="dy001"> 
     <留言 name="Who are you" type="zs" id="zs005"> 
        <title>什么是ASP</title> 
        <author>cxx</author> 
        <adddate>2001-02-20</adddate> 
        <content>ASP:Active Server Page</content> 
     </留言> 
     <留言 name="你好" type="zs" id="zs006"> 
        <title>什么是ASP</title> 
        <author>cxx</author> 
        <adddate>2001-02-20</adddate> 
        <content>ASP:Active Server Page</content> 
     </留言> 
  </单元> 
  <单元 name="我的留言" type="dy" id="dy003"/> 
</留言簿> 
<留言簿 name="留言簿" type="ly" id="ly001"/> 
</Ebaihe> 
bianli.asp文件

复制代码 代码如下:<% @LANGUAGE=VBScript%> 
<% 
function getimgstr(ttid,ttname,ttlvl,tttype,ttlf,ttlstr) 
   dim ttstr1 
   if ttlvl=0 then 
         ttstr1=ttstr1 & "<a href=" & chr(34) & "#" & chr(34)  
         ttstr1=ttstr1 & " onclick=" & chr(34) & "call OnClickDiv('" & ttid & "','" & "2" & "')"  
         ttstr1=ttstr1 & chr(34) & ">"  
         ttstr1= ttstr1 & "<img border=" & chr(34) & "0" & chr(34) & " src="/UploadFiles/2021-04-02/ & chr(34)  
         ttstr1= ttstr1 & ">         ttstr1=ttstr1 & "<a href=" & chr(34) & "#" & chr(34)  
         ttstr1=ttstr1 & " onclick=" & chr(34) & "call OnClickDiv('" & ttid & "','" & "2" & "')" 
         ttstr1=ttstr1 & chr(34) & ">"  
         ttstr1=ttstr1 & ttname & "</a><br>" & vbcrlf 
         ttstr1=ttstr1 & "<div id=" & chr(34) & ttid & chr(34) & " style=display:none>" & vbcrlf 
   else 
      for i= 2 to len(ttlstr)-1 
         if mid(ttlstr,i,1)="1" then 
            ttstr1 = ttstr1 & "<img border=" & chr(34) & "0" & chr(34) & " src="/UploadFiles/2021-04-02/ & chr(34)  
            ttstr1 = ttstr1 & ">         end if 
         if mid(ttlstr,i,1)="0" then 
            ttstr1 = ttstr1 & "<img border=" & chr(34) & "0" & chr(34) & " src=" & chr(34)  
            ttstr1 = ttstr1 & ">         end if 
      next 
      if tttype=1 then 
         ttstr1= ttstr1 & "<a href=" & chr(34) & "#" & chr(34)  
         ttstr1=ttstr1 & " onclick=" & chr(34) & "call OnClickDiv('" & ttid & "','" & ttlf & "')" 
         ttstr1=ttstr1 & chr(34) & ">"  
         ttstr1=ttstr1 & "<img border=" & chr(34) & "0" & chr(34) & " src=" & chr(34)  
         if ttlf=0 then 
            ttstr1= ttstr1 & ">height=16></a>" 
         else 
            ttstr1= ttstr1 & "image/l-plus.gif" & chr(34) & " id=" & chr(34) & "l-" & ttid & chr(34) & "  
height=16></a>" 
         end if 
         ttstr1= ttstr1 & "<a href=" & chr(34) & "#" & chr(34)  
         ttstr1=ttstr1 & " onclick=" & chr(34) & "call OnClickDiv('" & ttid & "','" & ttlf & "')" 
         ttstr1=ttstr1 & chr(34) & ">"  
         ttstr1=ttstr1 & "<img border=" & chr(34) & "0" & chr(34) & " src="/UploadFiles/2021-04-02/ & chr(34)  
         ttstr1= ttstr1 & ">height=16></a>" 
         ttstr1= ttstr1 & "<a href=" & chr(34) & "#" & chr(34)  
         ttstr1=ttstr1 & " onclick=" &chr(34) & "call OnClickDiv('" & ttid & "','" & ttlf & "')" 
         ttstr1=ttstr1 & chr(34) & ">"  
         ttstr1=ttstr1 & ttname & "</a><br>" & vbcrlf 
         ttstr1=ttstr1 & "<div id=" & chr(34) & ttid & chr(34) & " style=display:none>" & vbcrlf 
      else 
         ttstr1 = ttstr1 & "<img border=" & chr(34) & "0" & chr(34) & " src="/UploadFiles/2021-04-02/ & chr(34)  
         if ttlf=0 then 
            ttstr1 = ttstr1 & ">         else 
            ttstr1 = ttstr1 & "image/l-line.gif" & chr(34) & " height=16>" 
         end if 
         ttstr1= ttstr1 & "<a href=" & chr(34) & "#" & chr(34)  
         ttstr1=ttstr1 & " onclick=" & chr(34) & "call OnClickDiv('" & ttid & "','3')" 
         ttstr1=ttstr1 & chr(34) & ">"  
         ttstr1=ttstr1 & "<img border=" & chr(34) & "0" & chr(34) & " src="/UploadFiles/2021-04-02/ & chr(34)  
         ttstr1= ttstr1 & ">height=16></a>" 
         ttstr1= ttstr1 & "<a href=" & chr(34) & "#" & chr(34)  
         ttstr1=ttstr1 & " onclick=" & chr(34) & "call OnClickDiv('" & ttid & "','3')" 
         ttstr1=ttstr1 & chr(34) & ">"  
         ttstr1=ttstr1 & ttname & "</a><br>" & vbcrlf 
         ttstr1=ttstr1 & "<div id=" & chr(34) & ttid & chr(34) & " style=display:none></div>" & vbcrlf 
      end if 
   end if  
   getimgstr=ttstr1  
end function 
Function ShowNode(node,mylvl,myleaf,mylstr) 
   dim ttstr 
   dim mystr  
   dim ttleaf 
   dim ttn 
   ttn=0 
   if myleaf=0 then 
      ttleaf=0 
   else 
      ttleaf=1 
   end if 
For Each child In node.childNodes 
    ttn=ttn+1 
    If (child.nodeType=1) Then  
       nod_name=child.Attributes.getnamedItem("name").Text  
       nod_type=child.Attributes.getnamedItem("type").Text 
       nod_id=child.Attributes.getnamedItem("id").Text 
       if nod_type<>"zs" then 
          If (child.hasChildNodes) Then 
             if ttn=node.childnodes.length then 
                mystr=mystr & getimgstr(nod_id,nod_name,mylvl,1,1,mylstr & "0") 
                ttstr=ShowNode(child,mylvl+1,1,mylstr & "0") 
             else 
                mystr=mystr & getimgstr(nod_id,nod_name,mylvl,1,0,mylstr & "1") 
                ttstr=ShowNode(child,mylvl+1,0,mylstr & "1") 
             end if 
             mystr=mystr & ttstr 
             mystr=mystr & "</div>" 
          else 
             if ttn=node.childnodes.length then 
                mystr=mystr & getimgstr(nod_id,nod_name,mylvl,0,1,mylstr & "0") 
             else 
                mystr=mystr & getimgstr(nod_id,nod_name,mylvl,0,0,mylstr & "1") 
             end if 
          End If 
       else 
          if ttn=node.childnodes.length then 
             mystr=mystr & getimgstr(nod_id,nod_name,mylvl,0,1,mylstr & "0") 
          else 
             mystr=mystr & getimgstr(nod_id,nod_name,mylvl,0,0,mylstr & "1") 
          end if 
       end if 
    end if 
Next 
ShowNode=mystr 
End Function 
  dim xmldoc 
  dim xmlstr 
  Set xmldoc = Server.CreateObject("Microsoft.XMLDOM") 
  xmldoc.async=false 
  xmldoc.load(Server.MapPath("knowledge.xml")) 
  xmlstr=ShowNode(xmldoc,0,0,"") 
'  set xmldoc=nothing 
'parent.results.display(source.transformNode(style)); 
%> 
<html> 

<head> 
</head> 

<body> 
<script language="VBScript"> 

dim olditem 

sub OnClickDiv(DivId,pType) 
   if (document.all(DivId).style.display="none") then 
      document.all(DivId).style.display="" 
      if (pType="0") then 
        document.all("l-"+DivId).src="/UploadFiles/2021-04-02/t-minus.gif">        document.all("p-"+DivId).src="image/o-fold.bmp">      end if 
      if (pType="1") then 
        document.all("l-"+DivId).src="/UploadFiles/2021-04-02/l-minus.gif">        document.all("p-"+DivId).src="image/o-fold.bmp">      end if 
      'if (pType="3") then 
      '  document.all("p-"+DivId).src="/UploadFiles/2021-04-02/o-fold.bmp">      'end if 
   else 
      document.all(DivId).style.display="none"  
      if (pType="0") then 
        document.all("l-"+DivId).src="image/t-plus.gif">        document.all("p-"+DivId).src="/UploadFiles/2021-04-02/c-fold.bmp">      end if 
      if (pType="1") then 
         document.all("l-"+DivId).src="image/l-plus.gif">         document.all("p-"+DivId).src="/UploadFiles/2021-04-02/c-fold.bmp">      end if 
      'if (pType="3") then 
      '  document.all("p-"+DivId).src="image/c-fold.bmp">      'end if 
    end if 
end sub 
</script> 
<font name="宋体" size="2"> 
<nobr><%=xmlstr%></nobr></font> 
</body>
上一篇:如何回到先前的页面的方法多中语言 原创
下一篇:利用ASP从远程服务器上接收XML数据的方法
一句话新闻
一文看懂荣耀MagicBook Pro 16
荣耀猎人回归!七大亮点看懂不只是轻薄本,更是游戏本的MagicBook Pro 16.
人们对于笔记本电脑有一个固有印象:要么轻薄但性能一般,要么性能强劲但笨重臃肿。然而,今年荣耀新推出的MagicBook Pro 16刷新了人们的认知——发布会上,荣耀宣布猎人游戏本正式回归,称其继承了荣耀 HUNTER 基因,并自信地为其打出“轻薄本,更是游戏本”的口号。
众所周知,寻求轻薄本的用户普遍更看重便携性、外观造型、静谧性和打字办公等用机体验,而寻求游戏本的用户则普遍更看重硬件配置、性能释放等硬核指标。把两个看似难以相干的产品融合到一起,我们不禁对它产生了强烈的好奇:作为代表荣耀猎人游戏本的跨界新物种,它究竟做了哪些平衡以兼顾不同人群的各类需求呢?
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 网站地图 SiteMap