TreeList数据加载!

 
    public partial class TLExample : DevExpress.XtraEditors.XtraForm
    {
        DataTable dt = new DataTable();
        public TLExample()
        {
            InitializeComponent();
            dt.Columns.Add("ID",System.Type.GetType("System.String"));
            dt.Columns.Add("ParentID", System.Type.GetType("System.String"));
            dt.Columns.Add("TreeNode", System.Type.GetType("System.String"));
        }

        private void TLExample_Load(object sender, EventArgs e)
        {
            dt.Rows.Add("1", "0", "根节点");
            dt.Rows.Add("2", "1", "子节点1");
            dt.Rows.Add("3", "1", "子节点2");
            dt.Rows.Add("4", "1", "子节点3");
            dt.Rows.Add("5", "1", "子节点4");
            treeList1.DataSource = dt;
        }

    }


1、添加基础表数据

2、基础表中含有ID,ParentID两个字段用来组织树的父子结构。

3、在Run Designer上设置显示列!

3、将符合规则的数据表直接绑定到TreeList控件上!

结果如图!

可是在实际的数据库中往往不会存在上面那种很标准的(含有ID,ParentID的数据)。所以我们不能直接将数据绑定到控件上就必须对控件进行处理。

解决方法:

方法一:

将数据库中的数据根据实际规则处理成含有ID跟ParentID的表,然后进行绑定。

方法二:

根据实际规则,逐层加载每个节点!

下面对方法二用一个实例讲解!

在电脑中,文件夹是一层层加载下去的就如同一个树,怎么样将系统中的链接加载到TreeList上以树的形式显示出来呢?

怎么样把这树显示在TreeList中?

系统中可以得知的数据:根节点\节点1   根节点\节点2  根节点\节点3

解决步骤:

1、加载第一级节点

2、判断是否含有子节点,若含有则继续加载

 代码:

1、加载第一级节点

DataTable dt = new DataTable();

TreeListNode tln;

dt.Columns.Add("ID", System.Type.GetType("System.String"));

dt.Columns.Add("TreeNode", System.Type.GetType("System.String"));

DataRow drView = dt.NewRow();

drView.BeginEdit();

drView["ID"] = Guid.NewGuid();

drView["TreeNode"] = "根节点";

drView.EndEdit();

tln = treeList1.AppendNode(drView.ItemArray,null);

2、判断是否含有子节点

      private bool IsHasChild(string name)        {            string midpt = "";            name为当前路径            与系统路径比较            若相等则含有子节点 返回TRUE            若不等则不含有子节点 返回FALSE        }

3、当含有子节点,则找到子节点并与第一步相同的操作将子节点加载到TreeList上!

其中包含的一些详细的方法在下一节中给出!!!

如果大家有更好的方法请发上来一起讨论!

 

 




            
阅读更多
个人分类: DEV控件使用!
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭