这是我的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>修改现有数据,及对数据做删除操作.
<?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>修改现有数据,及对数据做删除操作.
解决方案 »
- 只能删除数据库里的图片路径字段,如何实现一并删除文件夹下的对应图片?
- IIS和VS自带的服务器 连接SQL的问题
- 文本内容语音合成,能否给出例子(100分)
- 哪儿有微软的Expression Web Designer的教程?
- 请高手帮忙解决一个问题!~
- Visual studio 2010中在设计界面中不小心拖动了一张图片的大小使得整个页面图片大小都乱了有什么解决方法了?急急急……
- 孟老大来了,求教把SQL SERVER指定表的数据导入Access里面的方法
- 求助!~~大家帮帮忙
- ASPNETPAGER的运行问题555~~~
- 为什么任何出现在<Script>里的代码都运行不了?
- 为何在插入小数点的数到数据库中的时候前面的那个零会没了(如插入的数为0.123,插入后却成为.123)
- aspx页面中如何动态加载自己做的ascx组件?
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>
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>
不能满足我的需求...谢谢大伙了
已知有一个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);//显示子节点点文本
}
}