第三方控件DevExpress的TreeList绑定XML文件

研究了两天,网上也看了不少资料,但都是静态绑定到TreeList,就是在已知道表的情况下进行绑定,表中已经把KeyFieldName和ParentFieldName的关系确定好了,比较死板。我需要的功能自动根据XML进行确定KeyFieldName和ParentFieldName关系。所以确定二者关系就比较麻烦,我现在只能实现对三层的XML文件进行显示,四层的还会出错,正在进一步改进,记录如下:(草稿形式,不很规范,谅解)

private void btnopenFile_Click(object sender,EventArgs e)
{
OpenFileDialog openFile = new OpenFileDialog();
openFile.Title = "打开XML文件";
openFile.Filter = "XML文件(*.xml)|*.xml";
openFile.InitialDirectory = "C:\\";
openFile.ShowDialog();
string filepath = openFile.FileName;
this.treeList1.DataSource = SelectXml(filepath);

}

public static int parentId;
public static int Id;
private DataTable SelectXml(string xmlPath)
{
DataTable dt = new DataTable();
DataColumn did = new DataColumn("ID",Type.GetType("system.int32"));
DataColumn dParentID = new DataColumn("ParentID",Type.GetType("system.int32"));
DataColumn dNodeName = new DataColumn("节点名称",Type.GetType("System.String"));
dt.Columns.Add(did);
dt.Columns.Add(dParentID);
dt.Columns.Add(dNodeName);
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load(xmlPath);
//初始ID,ParentID
Id = 1;
parentId = 1;
//获取根节点
XmlElement xmlRootElement = xmlDoc.DocumentElement;
DaTarow dr = dt.NewRow();
dr["ID"] = Id;
dr["ParentID"] = 0;
dr["节点名称"] = xmlRootElement.Name.ToString();
dt.Rows.Add(dr);
Id++;
int Id1 = Id,pId;
int b = parentId,d = Id; //记录递归后的ID,ParentId变化
XmlNodeList xmlNodeList = xmlRootElement.ChildNodes;
foreach (XmlElement xmlElement in xmlNodeList)
{
XmlNode xmlnode = (XmlNode)xmlElement;
dr = dt.NewRow();
dr["ID"] =d;
dr["ParentID"] = parentId;
dr["节点名称"] = xmlnode.Name.ToString();
dt.Rows.Add(dr);
Id1 = d;
pId = b+1;
sort(xmlnode,Id1,pId,dt,ref d,ref b); //利用ref记录随时变化
}
return dt;
}


private void sort(XmlNode xmlnode,int ID,int parentId,DataTable dt,ref int d,ref int b) { if (xmlnode.HasChildNodes) { XmlNodeList ChildNodeList = xmlnode.ChildNodes; foreach (XmlNode xmlNode in ChildNodeList) { if (xmlNode.NodeType == XmlNodeType.Text) { Id = Id - 1; ID = ID + 1; continue; } else { ID = ID + 1; DaTarow dr = dt.NewRow(); dr["ID"] = ID; dr["ParentID"] = parentId; dr["节点名称"] = xmlNode.Name.ToString(); Id = Id + 1; dt.Rows.Add(dr); sort(xmlNode,ID,Id - 1,ref b); } } } d=ID+1; b = ID; }

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


php输出xml格式字符串
J2ME Mobile 3D入门教程系列文章之一
XML轻松学习手册
XML入门的常见问题(一)
XML入门的常见问题(三)
XML轻松学习手册(2)XML概念
xml文件介绍及使用
xml编程(一)-xml语法
XML文件结构和基本语法
第2章 包装类
XML入门的常见问题(二)
Java对象的强、软、弱和虚引用
JS解析XML文件和XML字符串详解
java中枚举的详细使用介绍
了解Xml格式
XML入门的常见问题(四)
深入SQLite多线程的使用总结详解
PlayFramework完整实现一个APP(一)
XML和YAML的使用方法
XML轻松学习总节篇