转自:http://blog.sina.com.cn/s/blog_8944756d01016yaj.html

前台:

<asp:View ID="view0" runat="server">
                <asp:TreeView ID="treeLanMu" runat="server" ImageSet="Arrows"
                    onselectednodechanged="treeLanMu_SelectedNodeChanged"  >
                </asp:TreeView>
            </asp:View>

后台:

/// <summary> 
        /// 递归绑定子节点 
        /// </summary> 
        /// <param name="dt">作为数据源的DataTable</param> 
        /// <param name="tnc">该节点的子节点集合</param> 
        /// <param name="pid_val">该节点的父节点值</param> 
        /// <param name="id_Name">DataTable中id字段的名称</param> 
        /// <param name="pid_Name">DataTable中父id字段的名称</param> 
        /// <param name="text_Name">DataTable中name字段的名称</param> 
        private void BindTreeView(DataTable dt, TreeNodeCollection tnc, string pid_val, string id_Name, string pid_Name, string text_Name)
        {
            dt = GetAllLanmu();
            DataView dv = new DataView(dt);//将DataTable存到DataView中,以便于筛选数据 
            TreeNode tn;//建立TreeView的节点(TreeNode),以便将取出的数据添加到节点中 
            //以下为三元运算符,如果父id为空,则为构建“父id字段 is null”的查询条件,否则构建“父id字段=父id字段值”的查询条件 
            string filter = string.IsNullOrEmpty(pid_val) ? pid_Name + " is null" : string.Format(pid_Name + "='{0}'", pid_val);
            dv.RowFilter = filter;//利用DataView将数据进行筛选,选出相同 父id值 的数据 
            foreach (DataRowView drv in dv)
            {
                tn = new TreeNode();//建立一个新节点 
                tn.Value = drv[id_Name].ToString();//节点的Value值,一般为数据库的id值 
                tn.Text = drv[text_Name].ToString();//节点的Text,节点的文本显示 
                tnc.Add(tn);//将该节点加入到TreeNodeCollection(节点集合)中 
                BindTreeView(dt, tn.ChildNodes, tn.Value, id_Name, pid_Name, text_Name);//递归(反复调用这个方法,直到把数据取完为止) 
            }
        }

调用:

DataTable dtGetN = db.GetAllLanmu();
             BindTreeView(dtGetN, treeLanMu.Nodes, null, "lindex", "parentindex", "lname");
             treeLanMu.ExpandAll();

另一种方法:

private void BindTreeView()

{

treeLanMu.Nodes.Clear();

DataTable dtpindex = db.GetAllByParentIndex("-1");

TreeNode unitNode = new TreeNode();

if (dtpindex.Rows.Count!=0)

{

for (int i = 0; i < dtpindex.Rows.Count; i++)

{

string Pname = dtpindex.Rows[i]["lname"].ToString();

unitNode.Text = Pname;

treeLanMu.Nodes.Add(unitNode);

BindDepartmentTree(dtpindex.Rows[i]["lindex"].ToString(), unitNode);

}

}

}

private void BindDepartmentTree(string parentId, TreeNode node)

{

DataTable dt = db.GetAllByParentIndex(parentId);

for (int i = 0; i < dt.Rows.Count; i++)

{

string id = dt.Rows[i]["lindex"].ToString();

string name = dt.Rows[i]["lname"].ToString();

TreeNode snode = new TreeNode(name);

snode.Value = id;

node.ChildNodes.Add(snode);

BindDepartmentTree(id, snode);

}

}

《转》---使用递归方法DataTable 绑定 TreeView的更多相关文章

  1. datatable绑定comboBox显示数据[C#]

    实现功能: datatable绑定comboBox,在下拉菜单中显示对应数据 实现方法: 1.生成datatable,并为combox绑定数据源: comboBox1.DataSource = dt1 ...

  2. 【Winform】DataTable绑定到ComboBox

    我们从数据库中查询出来的数据存放在Datatable中 1.DataTable绑定到ComboBox上 cmbRole.DataSource = datatable; cmbRole.DisplayM ...

  3. DataGridView插入一行数据和用DataTable绑定数据2种方式

    以前不会用DataGridView的时候一直使用DataTable绑定的方式,如下: DataTable table = new DataTable(); //给表添加一列Name,此名字和 tabl ...

  4. datatable绑定comboBox,在下拉菜单中显示对应数据

    实现功能: datatable绑定comboBox,在下拉菜单中显示对应数据 实现方法: .生成datatable,并为combox绑定数据源: comboBox1.DataSource = dt1; ...

  5. HTTP模拟工具【C#/Winform源码】、Json绑定TreeView控件、使用了MetroModernUI、RestSharp、Dapper.Net、Newtonsoft.Json、SmartThreadPool这几个主要开源框架

    HTTP模拟工具 开发语言:C#/Winform开发工具:Visual Studio 2017数据库:   SQLite使用框架:界面-MetroModernUI              Http请 ...

  6. c# 后台绑定treeview 多个tab

    <wijmo:C1Tabs ID="C1Tab1" runat="server" ><%--OnSelectedChanged="& ...

  7. 循环遍历DataTable绑定到Table

    VoteList2.cs: using System; using System.Collections.Generic; using System.Linq; using System.Web; u ...

  8. bootstrap DataTable绑定数据带服务器分页

    <!-- DataTables -->  这两个文件在我的文件夹里面<script src="~/bower_components/datatables.net/js/jq ...

  9. c# 后台绑定treeview 单个tab

    <wijmo:C1TreeView ID="C1TreeView1" runat="server" ShowCheckBoxes="true&q ...

随机推荐

  1. PHPwebshell分析

    这几天已知在做webshell的检测,JSP的不说了,特征检测起来很好匹配到,而且全是一家亲,互相模仿的居多. 今天看了一篇文章,看到14年蘑菇的webshell的后门然后很不错. ========= ...

  2. 字符串处理:ABAP中的正则表达式

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  3. Android——android必看 各个控件属性(网上看到的文字,觉得挺好的,珍藏了)

    属性 值 说明 Android:orientation horizontal/vertical 设置布局水平还是垂直,默认是垂直 android:checked true/false 标记默认选中,如 ...

  4. iOS - Swift NSDate 时间

    前言 NSDate public class NSDate : NSObject, NSCopying, NSSecureCoding NSDate 用来表示公历的 GMT 时间(格林威治时间).是独 ...

  5. Android批量图片加载经典系列——采用二级缓存、异步加载网络图片

    一.问题描述 Android应用中经常涉及从网络中加载大量图片,为提升加载速度和效率,减少网络流量都会采用二级缓存和异步加载机制,所谓二级缓存就是通过先从内存中获取.再从文件中获取,最后才会访问网络. ...

  6. java技术知识点

    1   自我介绍 2  做过的项目 (Java 基础) 3  Java的四个基本特性(抽象.封装.继承,多态),对多态的理解(多态的实现方式)以及在项目中那些地方用到多态 Java的四个基本特性 ◦  ...

  7. Yii2.0 依赖注入(DI)和依赖注入容器的原理

    依赖注入和依赖注入容器 为了降低代码耦合程度,提高项目的可维护性,Yii采用多许多当下最流行又相对成熟的设计模式,包括了依赖注入(Denpdency Injection, DI)和服务定位器(Serv ...

  8. 转:从开源项目学习 C 语言基本的编码规则

    从开源项目学习 C 语言基本的编码规则 每个项目都有自己的风格指南:一组有关怎样为那个项目编码约定.一些经理选择基本的编码规则,另一些经理则更偏好非常高级的规则,对许多项目而言则没有特定的编码规则,项 ...

  9. 对List里的对象元素进行排序

    public class Student { private int studentId; private String studentName; private int age; public St ...

  10. Java中的泛型方法

    泛型是什么意思在这就不多说了,而Java中泛型类的定义也比较简单,例如:public class Test<T>{}.这样就定义了一个泛型类Test,在实例化该类时,必须指明泛型T的具体类 ...