这是我的XML文档:
<?xml version="1.0" encoding="utf-8"?>
<TREENODES>
<TREENODES>
    <treenode Text="Dotnet">
         <treenode Text="VB.net" NavigateUrl="http://www.sohu.com" Target="main" />
         <treenode Text="C#" NavigateUrl="http://www.163.com" Target="main" />
         <treenode Text="js" />
</treenode>
    <treenode Text="Web" >
         <treenode Text="HTML" />
         <treenode Text="CSS" />
         <treenode Text="JS" />
    </treenode>
    <treenode Text="DataBase">
         <treenode Text="SqlServer" />
         <treenode Text="Orcale" />
         <treenode Text="db2" />
    </treenode>   
<treenode Text="Asp">
     <treenode Text="VBs" Src="http://www.163.com" />
     <treenode Text="js" />
</treenode>
</TREENODES>我要实现的是.在页面端对这个XML文档进行操作.包括插入新的数据,比如:
插入:,<treenode Text="System">
          <treenode Text="sys1" Src="http://" />
     </treenode>修改现有数据,及对数据做删除操作.

解决方案 »

  1.   

    我现在有这样一段代码:
    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
            Dim userdom1 = New XmlDocument, userdom2, userdom3, userdom4
            userdom1.load(Server.MapPath("Stu2.xml"))           '装载需要操作的XML文件
            userdom2 = userdom1.selectsinglenode("TREENODES")     '操作游标指向TREENODES节点,句柄给userdom2变量
            userdom3 = userdom1.createElement("treenode")            '新创建一名为treenode的节点,并将句柄给userdom3变量
            userdom3.setAttribute("Text", "VF")            '为userdom3添加节点属性,新属性名为Text,值为VF
            'userdom3.innerText = "测试"                         '设置userdom3节点所包含的数据
            userdom2.AppendChild(userdom3)                      'userdom2即TREENODES节点下添加userdom3所描述的treenode节点
            userdom1.save(Server.MapPath("Stu2.xml"))          '将变动后的新XML数据保存到user.xml
        End Sub但是还是不能实现我要的功能,也就是说这代码只能插入类似的数据:<treenode Text="Sys">
    测试
    </treenode>
      

  2.   

    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
            Dim userdom1 = New XmlDocument, userdom2, userdom3, userdom4
            userdom1.load(Server.MapPath("Stu2.xml"))           '装载需要操作的XML文件
            userdom2 = userdom1.selectsinglenode("TREENODES")     '操作游标指向TREENODES节点,句柄给userdom2变量
            userdom3 = userdom1.createElement("treenode")            '新创建一名为treenode的节点,并将句柄给userdom3变量
            userdom3.setAttribute("Text", "VF")            '为userdom3添加节点属性,新属性名为Text,值为VF
            'userdom3.innerText = "测试"                         '设置userdom3节点所包含的数据
            userdom2.AppendChild(userdom3)                      'userdom2即TREENODES节点下添加userdom3所描述的treenode节点
            userdom1.save(Server.MapPath("Stu2.xml"))          '将变动后的新XML数据保存到user.xml
        End Sub这个代码只能实现插入如下数据的操作:
    <treenode Text="Asp">
       
    </treenode>
    不能满足我的需求...谢谢大伙了
      

  3.   

    参考
    已知有一个XML文件(bookstore.xml)如下:
    <?xml version="1.0" encoding="gb2312"?>
    <bookstore>
      <book genre="fantasy" ISBN="2-3631-4">
        <title>Oberon's Legacy</title>
        <author>Corets, Eva</author>
        <price>5.95</price>
      </book>
    </bookstore>
     
    1、往<bookstore>节点中插入一个<book>节点:
       XmlDocument xmlDoc=new XmlDocument();
       xmlDoc.Load("bookstore.xml");
       XmlNode root=xmlDoc.SelectSingleNode("bookstore");//查找<bookstore>
       XmlElement xe1=xmlDoc.CreateElement("book");//创建一个<book>节点
       xe1.SetAttribute("genre","李赞红");//设置该节点genre属性
       xe1.SetAttribute("ISBN","2-3631-4");//设置该节点ISBN属性
     
       XmlElement xesub1=xmlDoc.CreateElement("title");
       xesub1.InnerText="CS从入门到精通";//设置文本节点
       xe1.AppendChild(xesub1);//添加到<book>节点中
       XmlElement xesub2=xmlDoc.CreateElement("author");
       xesub2.InnerText="候捷";
       xe1.AppendChild(xesub2);
       XmlElement xesub3=xmlDoc.CreateElement("price");
       xesub3.InnerText="58.3";
       xe1.AppendChild(xesub3);
     
       root.AppendChild(xe1);//添加到<bookstore>节点中
       xmlDoc.Save("bookstore.xml");
    //===============================================
    结果为:
    <?xml version="1.0" encoding="gb2312"?>
    <bookstore>
      <book genre="fantasy" ISBN="2-3631-4">
        <title>Oberon's Legacy</title>
        <author>Corets, Eva</author>
        <price>5.95</price>
      </book>
      <book genre="李赞红" ISBN="2-3631-4">
        <title>CS从入门到精通</title>
        <author>候捷</author>
        <price>58.3</price>
      </book>
    </bookstore>
     
    2、修改节点:将genre属性值为“李赞红“的节点的genre值改为“update李赞红”,将该节点的子节点<author>的文本修改为“亚胜”。
        XmlNodeList nodeList=xmlDoc.SelectSingleNode("bookstore").ChildNodes;//获取bookstore节点的所有子节点
       foreach(XmlNode xn in nodeList)//遍历所有子节点
       {
        XmlElement xe=(XmlElement)xn;//将子节点类型转换为XmlElement类型
        if(xe.GetAttribute("genre")=="李赞红")//如果genre属性值为“李赞红”
        {
         xe.SetAttribute("genre","update李赞红");//则修改该属性为“update李赞红”
     
         XmlNodeList nls=xe.ChildNodes;//继续获取xe子节点的所有子节点
         foreach(XmlNode xn1 in nls)//遍历
         {
          XmlElement xe2=(XmlElement)xn1;//转换类型
          if(xe2.Name=="author")//如果找到
          {
           xe2.InnerText="亚胜";//则修改
           break;//找到退出来就可以了
          }
         }
         break;
        }
       }
     
       xmlDoc.Save("bookstore.xml");//保存。
    //==================================================
    最后结果为:
    <?xml version="1.0" encoding="gb2312"?>
    <bookstore>
      <book genre="fantasy" ISBN="2-3631-4">
        <title>Oberon's Legacy</title>
        <author>Corets, Eva</author>
        <price>5.95</price>
      </book>
      <book genre="update李赞红" ISBN="2-3631-4">
        <title>CS从入门到精通</title>
        <author>亚胜</author>
        <price>58.3</price>
      </book>
    </bookstore>
     
    3、删除 <book genre="fantasy" ISBN="2-3631-4">节点的genre属性,删除 <book genre="update李赞红" ISBN="2-3631-4">节点。
    XmlNodeList xnl=xmlDoc.SelectSingleNode("bookstore").ChildNodes;
     
       foreach(XmlNode xn in xnl)
       {
        XmlElement xe=(XmlElement)xn;
        if(xe.GetAttribute("genre")=="fantasy")
        {
         xe.RemoveAttribute("genre");//删除genre属性
        }
        else if(xe.GetAttribute("genre")=="update李赞红")
        {
         xe.RemoveAll();//删除该节点的全部内容
        }
       }
       xmlDoc.Save("bookstore.xml");
    //===========================================
    最后结果为:
    <?xml version="1.0" encoding="gb2312"?>
    <bookstore>
      <book ISBN="2-3631-4">
        <title>Oberon's Legacy</title>
        <author>Corets, Eva</author>
        <price>5.95</price>
      </book>
      <book>
      </book>
    </bookstore>
     
    4、显示所有数据。
       XmlNode xn=xmlDoc.SelectSingleNode("bookstore");
     
       XmlNodeList xnl=xn.ChildNodes;
       
       foreach(XmlNode xnf in xnl)
       {
        XmlElement xe=(XmlElement)xnf;
        Console.WriteLine(xe.GetAttribute("genre"));//显示属性值
        Console.WriteLine(xe.GetAttribute("ISBN"));
     
        XmlNodeList xnf1=xe.ChildNodes;
        foreach(XmlNode xn2 in xnf1)
        {
         Console.WriteLine(xn2.InnerText);//显示子节点点文本
        }
       }