利用TreeList加载XML文件

第一次学习弄,也是上网看别人的思路,主要就是首先将XML读取到表里面,然后利用TreeList的两个属性:KeyFieldName和ParentFieldName两个属性的值,认分别是ID,ParentID,二者的关系就是涉及到树形结构的层次关系。所创建的表中务必要包含二两个属性。下面上代码
            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);
      int Id = 1;
      int ParentId=0;
      //获取根节点
      XmlElement xmlRootElement=xmlDoc.DocumentElement;
      DaTarow dr = dt.NewRow();
      dr["ID"] = Id++;
      dr["ParentID"] = 0;
      dr["节点名称"] = xmlRootElement.Name.ToString();
      dt.Rows.Add(dr);
      XmlNodeList xmlNodeList = xmlRootElement.ChildNodes;
      foreach (XmlElement xmlElement in xmlNodeList)
      {
        dr = dt.NewRow();
        dr["ID"] = Id++;
        dr["ParentID"] = ParentId;
        dr["节点名称"] = xmlElement.Name.ToString();
        dt.Rows.Add(dr);
        int parentId = Id-1;
        //遍历该节点下面的子节点
        XmlNodeList ChildNodeList = xmlElement.ChildNodes;
        foreach (XmlNode xmlNode in ChildNodeList)
        {
          dr = dt.NewRow();
          dr["ID"] = Id++;
          dr["ParentID"] = parentId;
          dr["节点名称"] = xmlNode.Name.ToString();
          dt.Rows.Add(dr);
        }    
      }
  this.treeList1.DataSource=dt;

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 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轻松学习总节篇