• 操作xml


     

    脚本代码:实例解析Js+XML的操作方法

    我的xml文件Login.xml如下.
    <?xml version="1.0" encoding="utf-8" ?>
    <Login>
        <Character>
            <C Text="
    热血" Value="0"></C>
            <C Text="
    弱气" Value="1"></C>
            <C Text="
    激情" Value="2"></C>
            <C Text="
    冷静" Value="3"></C>
            <C Text="
    冷酷" Value="4"></C>
        </Character>
        <Weapon>
            <W Text="
    光束剑" Value="0"></W>
            <W Text="
    光束配刀" Value="1"></W>
        </Weapon>
        <EconomyProperty>
            <P Text="
    平均型" Value="0"></P>
            <P Text="
    重视攻击" Value="1"></P>
            <P Text="
    重视敏捷" Value="2"></P>
            <P Text="
    重视防御" Value="3"></P>
            <P Text="
    重视命中" Value="4"></P>
        </EconomyProperty>
    </Login>
    现在我需要对这个xml文件的内容进行操作.
    首先,我们需要加载这个xml文件,js中加载xml文件,是通过XMLDOM来进行的.
    //
    加载xml文档
    loadXML    = function(xmlFile)
    {
        var xmlDoc;
        if(window.ActiveXObject)
        {
            xmlDoc    = new ActiveXObject('Microsoft.XMLDOM');
            xmlDoc.async    = false;
            xmlDoc.load(xmlFile);
        }
        else if (document.implementation&&document.implementation.createDocument)
        {
            xmlDoc    = document.implementation.createDocument('', '', null);
            xmlDoc.load(xmlFile);
        }
        else
        {
            return null;
        }
       
        return xmlDoc;
    }

    xml文件对象出来了, 接下去我就要对这个文档进行操作了.
    比如说,我们现在需要得到节点Login/Weapon/W的第一个节点的属性,那么我们可以如下进行.


    //
    首先对xml对象进行判断
    checkXMLDocObj    = function(xmlFile)
    {
        var xmlDoc    = loadXML(xmlFile);
        if(xmlDoc==null)
        {
            alert('
    您的浏览器不支持xml文件读取,于是本页面禁止您的操作,推荐使用IE5.0以上可以解决此问题!');
            window.location.href='/Index.aspx';
        }
       
        return xmlDoc;
    }

    // 然后开始获取需要的Login/Weapon/W的第一个节点的属性值
    var xmlDoc    = checkXMLDocObj('/EBS/XML/Login.xml');
    var v    = xmlDoc.getElementsByTagName('Login/Weapon/W')[0].childNodes.getAttribute('Text')
    而我在我的程序中的写法是这样子的,当然我在程序中的写法是已经应用到实际中的了.一并给出来,以供查看
    initializeSelect    = function(oid, xPath)
    {
        var xmlDoc    = checkXMLDocObj('/EBS/XML/Login.xml');
        var n;
        var l;
        var e    = $(oid);
        if(e!=null)
        {
            n    = xmlDoc.getElementsByTagName(xPath)[0].childNodes;
            l    = n.length;
            for(var i=0; i<l; i++)
            {
                var option    = document.createElement('option');
                option.value    = n[i].getAttribute('Value');
                option.innerHTML    = n[i].getAttribute('Text');
                e.appendChild(option);
            }
        }
    }
    上面的访问代码中,我们是通过xmlDoc.getElementsByTagName(xPath)来进行的.
    还可以通过xmlDoc.documentElement.childNodes(1)..childNodes(0).getAttribute('Text')进行访问.
    一些常用方法:
    xmlDoc.documentElement.childNodes(0).nodeName,
    可以得到这个节点的名称.
    xmlDoc.documentElement.childNodes(0).nodeValue,
    可以得到这个节点的值. 这个值是来自于这样子的xml格式:<a>b</b>, 于是可以得到b这个值.
    xmlDoc.documentElement.childNodes(0).hasChild,
    可以判断是否有子节点

    根据我的经验,最好是使用getElementsByTagName(xPath)的方法对节点进行访问,因为这样子可以直接通过xPath来定位节点,这样子会有更好的性能.

    asp.net xml文件的读写,添加,修改,删除操作

     

    asp.net xml文件的读写,添加,修改,删除操作
    下面有代码调试正确

    using System;
    using System.Collections;
    using System.ComponentModel;
    using System.Data;
    using System.Drawing;
    using System.Web;
    using System.Web.SessionState;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using System.Web.UI.HtmlControls;
    using System.Xml;
    private XmlDocument xmlDoc;

            //load xml file
            private void LoadXml()
            {
                xmlDoc=new XmlDocument();
                xmlDoc.Load(Server.MapPath("User.xml"));
            }


            //
    添加节点
            private void AddElement()
            {
                
                LoadXml();

                XmlNode xmldocSelect=xmlDoc.SelectSingleNode("user");
                
                XmlElement el=xmlDoc.CreateElement("person"); //
    添加person节点
                el.SetAttribute("name","
    风云"); //添加person节点的属性"name"
                el.SetAttribute("sex","
    ");   //添加person节点的属性 "sex"
                el.SetAttribute("age","25");   //
    添加person节点的属性 "age"
                
                 XmlElement xesub1=xmlDoc.CreateElement("pass"); //
    添加person节点的里的节点
                 xesub1.InnerText="123";//
    设置文本节点
                 el.AppendChild(xesub1);
                 XmlElement xesub2=xmlDoc.CreateElement("Address");
                 xesub2.InnerText="
    昆明";//设置文本节点
                 el.AppendChild(xesub2);

                xmldocSelect.AppendChild(el);
                xmlDoc.Save(Server.MapPath("user.xml"));


            }


            

            //
    修改节点
            private void UpdateElement()
            {
                LoadXml();
                XmlNodeList nodeList=xmlDoc.SelectSingleNode("user").ChildNodes;//
    获取bookstore节点的所有子节点
                foreach(XmlNode xn in nodeList)//
    遍历所有子节点
                {
                    XmlElement xe=(XmlElement)xn;//
    将子节点类型转换为XmlElement类型
                    if(xe.GetAttribute("name")=="
    风云")//如果name属性值为风云
                    {
                        xe.SetAttribute("name","
    发明");

                        
                        //
    如果下面有子节点在下走
                         XmlNodeList nls=xe.ChildNodes;//
    继续获取xe子节点的所有子节点
                        foreach(XmlNode xn1 in nls)//
    遍历
                        {
                           XmlElement xe2=(XmlElement)xn1;//
    转换类型
                            if(xe2.Name=="pass")//
    如果找到
                            {
                                xe2.InnerText="66666";//
    则修改
                                break;

                            }
                        }

                        break;
                    }
                }
               xmlDoc.Save(Server.MapPath("user.xml"));//
    保存
            }


            //
    删出节点
            private void deleteNode()
            {
                
                LoadXml();
                XmlNodeList xnl=xmlDoc.SelectSingleNode("user").ChildNodes;
     
                foreach(XmlNode xn in xnl)
                {
                    XmlElement xe=(XmlElement)xn;
                    
                    if(xe.GetAttribute("name")=="
    发明")
                    {
                        //xe.RemoveAttribute("name");//
    删除name属性
                        xe.RemoveAll();//
    删除该节点的全部内容

                        
                        break;
                    }
                    
                }
                xmlDoc.Save(Server.MapPath("user.xml"));//
    保存
            }

            private void showIt()
            {
                LoadXml();
                XmlNode xn=xmlDoc.SelectSingleNode("user");
     
                XmlNodeList xnl=xn.ChildNodes;
       
                foreach(XmlNode xnf in xnl)
                {
                    XmlElement xe=(XmlElement)xnf;
    //                Console.WriteLine(xe.GetAttribute("name"));//
    显示属性值
    //                Console.WriteLine(xe.GetAttribute("sex"));
    // 
    //                XmlNodeList xnf1=xe.ChildNodes;
    //                foreach(XmlNode xn2 in xnf1)
    //                {
    //                    Console.WriteLine(xn2.InnerText);//
    显示子节点点文本
    //                }

                }

            }
        
    Xml
    的样式:
    <?xml version="1.0" encoding="gb2312"?>
    <user>
      <person>
      </person>
      <person name="
    风拉" sex="" age="25">
        <pass>123</pass>
        <Address>
    大明</Address>
      </person>
      <person name="
    风云" sex="" age="25">
        <pass>123</pass>
        <Address>
    昆明</Address>
      </person>
    </user>

  • 相关阅读:
    C/C++知识点收集
    JAVA相关知识点理解
    Windows相关收集
    【原创】java的反射机制
    【原创】如何配置声明书事务
    【原创】spring中的事务传播特性
    【摘录】JAVA内存管理-自动选择垃圾收集器算法
    【摘录】JAVA内存管理-JVM垃圾收集机制
    【摘录】数据库拆分的一般方法和原则
    【摘录】JAVA内存管理-有关垃圾收集的关键参数
  • 原文地址:https://www.cnblogs.com/cuihongyu3503319/p/672091.html
Copyright © 2020-2023  润新知