hta实现的笨狼树状节点查看器
来源: 阅读:792 次 日期:2014-08-12 17:48:36
温馨提示: 小编为您整理了“hta实现的笨狼树状节点查看器”,方便广大网友查阅!

<html>

<head>

<style>

table

{

    border-collapse: collapse;

    border-width: 4; 

    border-style: double; 

    border-color:#15336F;

    font-size:12px;

}

body

{

    font-size:12px;

}

div

{

    width:100%;

    height:9; 

    border-style:solid; 

    border-width:1; 

    border-color:#eeeeee;    

    vertical-align:top;

    font-size:12;

    cursor:hand;

}

</style>

<title>笨狼树状节点查看器</title>

</head>

<body>

 <INPUT type="file" id=file1 name=file1>请输入xml文件路径

 <INPUT type="button" value="确定" onclick = "vbs:analyse ">

 <SELECT id="select1" onchange="vbs:analyse">

        <OPTION value="nodeName" >显示标签</OPTION>

        <OPTION  value="text" >显示文字</OPTION>

        <OPTION  value="attribute" >显示属性</OPTION>

        <OPTION  value="XPath" >显示XPath</OPTION>

</SELECT>

<DIV id="oList" style="padding-left:0"></DIV>

</body>

 <script language="vbScript" >

    '**************************************

    '****作者:    超级大笨狼 superdullwolf****

    '**************************************        

        public dic,favour,anything    ,doc      

        set doc = CreateObject("Microsoft.XMLDOM")        

        doc.async=False

    sub analyse()

            dim myTR 

            favour = select1.value

            removeDIV  

            if not doc.load(file1.value) then 

                alert "文件加载失败,请检查文件是否存在!"    

            else

                Set rootNode = doc.DocumentElement

                set rootDIV = document.createElement("DIV")    

                rootDIV.setAttribute "XPath",rootNode.nodeName 

                oList.setAttribute "XPath",rootNode.nodeName                  

                oList.setAttribute "parsed",false

                appendDIV     oList,rootNode    

            end if

    end sub

    sub appendDIV(myDIV,myNode)    

        dim myChild    ,newDIV,ChildID,thisID ,ChildXPath

        

        for each myChild in myNode.childNodes

            if     myChild.nodeName <> "#text"    then    

                set newDIV = document.createElement("DIV")            

                myDIV.appendChild    newDIV            

                addPx newDIV, myDIV,10    '缩进10象素

                ChildID = 0

                ChildXPath = myDIV.getAttribute("XPath") & "/" & myChild.nodeName & "[" & ChildID & "]"    

                do while not doc.selectSingleNode(ChildXPath) is myChild

                    ChildID=ChildID+1

                    ChildXPath = myDIV.getAttribute("XPath") & "/" & myChild.nodeName & "[" & ChildID & "]"    

                loop

                newDIV.setAttribute "XPath",ChildXPath 

                newDIV.setAttribute "parsed",false    '子元素还没标记过了。

                newDIV.title = newDIV.getAttribute("XPath") 

                newDIV.innerText = getText(myChild,newDIV) 

                if myChild.childNodes.length>0 then 

                        newDIV.attachEvent "onclick",GetRef("attachOnclick")

                end if

            end if                     

        next

        myDIV.setAttribute "parsed",true'所有子元素都标记过了。

    end sub    

    sub removeDIV()             

        dim oldDIV

        for each  oldDIV in   oList.childNodes          

               oldDIV.removeNode(true)             

         next     

    end sub

    sub attachOnclick()

        dim obj    ,nodeXPath,cDIV

        set obj=window.event.srcElement 

        nodeXPath = obj.getAttribute("XPath")

        if instr(nodeXPath,"#text") >0 then 

            window.event.cancelBubble = true

            exit sub

        end if

        if not obj.getAttribute("parsed")= true then     

             appendDIV obj ,doc.selectSingleNode(nodeXPath)

        else

            for each cDIV in obj.children

                if cDIV.style.display = "none" then

                    cDIV.style.display = ""

                else

                    cDIV.style.display = "none"

                end if

            next

        end if

        window.event.cancelBubble = true         

    end sub

    function getText(myNode,oDIV)

        dim myAttribute

        getText = ""

        select case favour

            case "text"

                if not isnull(myNode.text) then

                    getText = myNode.text

                 else

                    getText = "空文字"

                 end if            

            case "nodeName"                 

                    getText = myNode.nodeName    

            case "attribute"    

                if myNode.nodeName <>"#text" then

                    for each myAttribute in  myNode.attributes                         

                        getText =getText &  myAttribute.name

                        getText = getText & "=" & chr(34) 

                        getText = getText & myAttribute.value  & chr(34) & " "

                    next

                    getText = trim(getText)

                end if

             

            case "XPath"

                getText = oDIV.title

        end select

        if trim(getText) ="" then getText ="空"

    end function

    sub addPx(newDIV,oldDIV,num)

        dim re,myString    

        set re = new RegExp

        re.Global = true

        re.Pattern = "[^\d]*"            

        myString =  re.Replace(oldDIV.style.paddingLeft, "")

        if myString ="" then myString = "0"

        myString = (cint(myString) + num ) & "px"

        newDIV.style.paddingLeft = myString

        set re = nothing

    end sub

 </script>

</html>

更多信息请查看IT技术专栏

更多信息请查看脚本栏目
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!

2025国考·省考课程试听报名

  • 报班类型
  • 姓名
  • 手机号
  • 验证码
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map