c#TreeList与Xml操作结合
更新时间:2023-04-24 07:10:01 阅读量: 实用文档 文档下载
Visual C#2005中的TreeView控件的使用
分类: Visual C# 20052007-08-09 17:253085人阅读评论(9)收藏举报
目录(?)[+]
最近在一个项目中遇到处理树状层次关系的数据,于是就暂时使用了TreeView来实现,我把其中的主要功能提了出来做成了一个Demo程序,在这里和大家分享,希望各位多多指教。下面就是实现的主要功能以及源码下载。
读取XML文件中的树状结构数据,并用TreeView控件呈现 在相同层级中前后/上下移动节点
删除指定值的节点
把TreeView的节点存储到XML文件中 开发环境:Windows XP SP2, Visual Studio 2005 with SP1
XML数据的组织结构
我的XML数据结构如下所示: <?xml version="1.0" encoding="utf-8"?> <TestTreeView>
<TestNode nodeText="Test1" nodeValue="a" />
<TestNode nodeText="Test2" nodeValue="b">
<TestNode nodeText="Test3" nodeValue="c">
<TestNode nodeText="Test4" nodeValue="d" />
<TestNode nodeText="Test5" nodeValue="e" />
</TestNode>
<TestNode nodeText="Test6" nodeValue="f" />
</TestNode>
<TestNode nodeText="Test7" nodeValue="c" />
</TestTreeView>
其中"nodeText"为在
TreeView中显示的节点文本,"nodeValue"为该节
点实际存储的值,而" a,b,c,d,e,f "为预定义的6个测试值 用TreeView控件呈现XML数据 把上述的XML文件的数据呈现到TreeView控件中主要使用了如下的递归处理:
#region 变量
private bool enabled = false;
private string strXmlPath = null;
private XmlDocument xmlDoc = null;
#endregion
#region 方法
/// <summary>
/// 根据XML文件加载树节点
/// </summary>
/// <param name="xmlPath">要加载的XML文件路径</param>
private void LoadTreeNodes(string xmlPath)
{
this.xmlDoc = new XmlDocument();
try
{
this.xmlDoc.Load(xmlPath);
XmlNodeList nodes = this.xmlDoc.SelectNodes("TestTreeView/TestNode");
this.treeMain.BeginUpdate();
this.treeMain.Nodes.Clear();
this.ConvertXmlNodeToTreeNode(nodes, this.treeMain.Nodes);
this.treeMain.EndUpdate();
}
catch (Exception ex)
{ MessageBox.Show("程序发生错误:" + ex.Message,
"异常", MessageBoxButtons.OK, MessageBoxIcon.Error); } } private void ConvertXmlNodeToTreeNode(XmlNodeList
xmlNodes, TreeNodeCollection treeNodes) { foreach (XmlNode xmlNode in xmlNodes)
{
string nodeText = xmlNode.Attributes["nodeText"].Value;
string nodeValue = xmlNode.Attributes["nodeValue"].Value;
TreeNode newTreeNode = new TreeNode(nodeText);
newTreeNode.Tag = nodeValue;
if (xmlNode.HasChildNodes)
{
this.ConvertXmlNodeToTreeNode(xmlNode.ChildNodes, newTreeNode.Nodes);
}
treeNodes.Add(newTreeNode);
}
}
#endregion
在相同层级中前后/上下移动节点
这里的移动节点没有使用常见的定义一个Temp变量来存储临时数据,然后把要移动的2个数据交换位置。以“上移”为例,先把要移动的节点删除,再在该节点的前一个节点的位置插入该节点,在删除前把该节点存储在一个临时变量中,而“下移”则类似,下面是主要的代码:
// 在同级中上移当前节点
private void btnMoveUp_Click(object sender, EventArgs e)
{
TreeNode current = this.treeMain.SelectedNode;
TreeNode temp = null;
if (current != null)
{
temp = current;
TreeNode prev
= current.PrevNode; if (current.Parent != null) { TreeNode parent = current.Parent; parent.Nodes.Remove(current); parent.Nodes.Insert(prev.Index, temp); } else { this.treeMain.Nodes.Remove(current); this.treeMain.Nodes.Insert(prev.Index, temp); } this.treeMain.SelectedNode = temp; } }
// 在同级中下移当前节点
private void btnMoveDown_Click(object sender, EventArgs e)
{
TreeNode current = this.treeMain.SelectedNode;
if (current != null)
{
TreeNode next = current.NextNode;
if (next != null)
{
TreeNode temp = next;
if (current.Parent != null)
{
TreeNode parent = current.Parent;
parent.Nodes.Remove(next);
parent.Nodes.Insert(current.Index, temp);
}
else
{
this.treeMain.Nodes.Remove(next);
this.treeMain.Nodes.Insert(current.Index, temp);
}
this.treeMain.SelectedNode = temp;
this.treeMain.SelectedNode = current;
}
}
} 删除指定值的节点 TreeView节点实际存储的值保存在TreeNode.Tag中,选择要删除的值,然后搜索定位所有节点,最后删除这些节点,重点是遍历所有TreeView的节点搜索具有该值的节点,下面是主要代码:
// 定位指定值的节点,其中listNodesLocated是一个ListBox控件 // 列出所有定位到的节点的名称 private void LocateNodeWithValue(TreeNodeCollection nodes, string nodeValue) { foreach (TreeNode node in nodes)
{
if (node.Tag.ToString() == nodeValue)
{
this.listNodesLocated.Items.Add(node.Text);
}
if (node.Nodes.Count > 0)
{
this.LocateNodeWithValue(node.Nodes, nodeValue);
}
}
}
// 删除上述方法定位到的节点
private void DeleteNode(TreeNodeCollection nodes, string valueToDelete)
{
foreach (TreeNode node in nodes)
{
if (node.Tag.ToString() == valueToDelete)
{
nodes.Remove(node);
this.listNodesLocated.Items.Remove(node.Text);
}
else if (node.Nodes.Count > 0)
{
this.DeleteNode(node.Nodes, valueToDelete);
} } } 保存TreeView的节点到XML文件中 把编辑后的TreeView
中的TreeNode类型的节点转换成XmlNode类型节点保存到XML文件中,该XML文件就是最初选择加载的XML文件,在保存之前要先删除XML
中TestTreeView根节点下的所有子节点,主要方法如下:
// 保存主方法
private void SaveTreeNodes(string filePath)
{
if (this.xmlDoc != null)
{
XmlNode root = this.xmlDoc.SelectSingleNode("TestTreeView");
// 删除根节点下的所有原有节点
root.RemoveAll();
this.ConvertTreeNodesToXmlNodes(this.treeMain.Nodes, root);
this.xmlDoc.Save(this.strXmlPath);
MessageBox.Show("保存成功!", "信息", MessageBoxButtons.OK, rmation); }
}
// 把TreeNode转换成对应的XmlNode
private void ConvertTreeNodesToXmlNodes(TreeNodeCollection treeNodes, XmlNode xmlNode) {
XmlDocument doc = xmlNode.OwnerDocument;
foreach (TreeNode treeNode in treeNodes)
{
XmlNode newElement = null;
XmlAttribute attrValue = null;
newElement = doc.CreateNode(XmlNodeType.Element, "TestNode", "");
// Set "nodeText"
attrValue = doc.CreateAttribute("nodeText");
attrValue.Value = treeNode.Text;
newElement.Attributes.Append(attrValue); // Set "nodeValue" attrValue = doc.CreateAttribute("nodeValue"); attrValue.Value = treeNode.Tag.ToString(); newElement.Attributes.Append(attrValue);
xmlNode.AppendChild(newElement);
if (treeNode.Nodes.Count > 0)
{
this.ConvertTreeNodesToXmlNodes(treeNode.Nodes, newElement);
}
}
}
这个Demo中的有些方法还有待改善,希望大家多给意见!
这是本人的第一篇Blog文章,从今天起我要坚持写一些东西,把在工作中用到的方法以及问题整理出来,和大家分享,借此机会来巩固自己的所学的知识,也希望能交到很多志同道合的朋友!谢谢
正在阅读:
c#TreeList与Xml操作结合04-24
少儿英语口语波兰的艺术教育08-19
四年级数学(下)第二单元考试试卷07-24
C语言文件选择题04-10
学科渗透法制教育八年级地理(上)渗透点03-27
山东青岛鼎信电力载波芯片BL336108-25
工科数学分析-数集和确界原理05-30
注会第11章个人所得税法(课后作业)10-07
学习《新时代党员领导干部自我革命须臾不可放松》有感03-28
2016年农信银题库汇总04-21
- 教学能力大赛决赛获奖-教学实施报告-(完整图文版)
- 互联网+数据中心行业分析报告
- 2017上海杨浦区高三一模数学试题及答案
- 招商部差旅接待管理制度(4-25)
- 学生游玩安全注意事项
- 学生信息管理系统(文档模板供参考)
- 叉车门架有限元分析及系统设计
- 2014帮助残疾人志愿者服务情况记录
- 叶绿体中色素的提取和分离实验
- 中国食物成分表2020年最新权威完整改进版
- 推动国土资源领域生态文明建设
- 给水管道冲洗和消毒记录
- 计算机软件专业自我评价
- 高中数学必修1-5知识点归纳
- 2018-2022年中国第五代移动通信技术(5G)产业深度分析及发展前景研究报告发展趋势(目录)
- 生产车间巡查制度
- 2018版中国光热发电行业深度研究报告目录
- (通用)2019年中考数学总复习 第一章 第四节 数的开方与二次根式课件
- 2017_2018学年高中语文第二单元第4课说数课件粤教版
- 上市新药Lumateperone(卢美哌隆)合成检索总结报告
- TreeList
- 结合
- 操作
- Xml
- 门禁设置软件V3.0使用说明
- 湖北省鄂州市吴都中学七年级英语上册 Unit10 Can you play the g
- 东城区2022届高三期中理科数学
- 大四工商管理专业毕业实习报告直接用
- 南京教师考编考试情况
- 智能钻杆_将引发一场井下信号传输技术革命
- 强力康项目可行性研究报告评审方案设计(2013年发改委标准案例范
- 人教版高一英语必修一第二单元English around the World (warmi
- 国家级经济技术开发区扩建审批原则和审批程序
- 精轧螺纹钢长度最长能生产多长的
- 吉林建筑大学毕业论文任务书范文模板
- 第8章-模块和VBA程序设计
- 汉字--从甲骨文到计算机
- 2012一轮5-4平面向量的应用
- IPQC、STC、IQC、FQC概念
- 苏教版五上《嫦娥奔月》第一课时教学设计
- 地球科学概论模拟题(开卷)
- 尼康单反D3200使用说明书
- 初中篮球单元教学计划_初中体育教案
- b-磷酸三钙在医用材料的应用