前台代码 (只需要有TreeView控件, 添加ID,其他默认生成)

<form id="form1" runat="server">
<div>

<asp:treeview ID="tree1" ExpandDepth="0" runat="server" />
</div>
</form>

后台代码

Page_Load代码

1         private string myConn = ConfigurationManager.ConnectionStrings["connectionString0"].ConnectionString;
2 protected void Page_Load(object sender, EventArgs e)
3 {
4 if (!IsPostBack)
5 {
6 BindTree(tree1);
7 }
8 }

获取节点

        /// <summary>
/// 获得节点 1--当前元素的第几层 2--上级ID 3--更改的数据集
/// </summary>
/// <param name="upDegree">当前元素的第几层</param>
/// <param name="upID">上级ID</param>
/// <param name="ds">更改的数据集</param>
/// <returns>是否成功</returns>
private bool getNode(int upDegree, string upID, ref DataSet ds) {
string myQuery = " select model_ID, model_name, up_ID, degree from Model where degree='" + upDegree + "' and up_ID='" + upID + "';";
SqlConnection conn = new SqlConnection(myConn);
conn.Open();
SqlDataAdapter da = new SqlDataAdapter(myQuery, conn);
da.Fill(ds);
conn.Close();
if (ds.Tables[0].Rows.Count>0)
{
return true;
}
return false;
}

绑定子节点

 1         /// <summary>
2 /// 绑定子节点 1--父节点所处级别 2--父节点 return Bool是否有子节点
3 /// </summary>
4 /// <param name="upDegree">第几级</param>
5 /// <param name="tn">父节点</param>
6 /// <returns>是否有子节点</returns>
7 private bool BindChild(int Degree, TreeNode tn){
8 DataSet ds = new DataSet();
9 getNode(Degree+1, tn.Value, ref ds); // 获取节点列表 比当前节点更多
10 DataTable dt = ds.Tables[0]; // 加快ds的读取速度
11 TreeNode tn2 = new TreeNode(); // 新增子节点
12
13 int len = dt.Rows.Count; // 子节点数量
14 bool flag = false; // 是否有子节点 false--无子节点 true--有子节点
15 for (int i = 0; i < len; i++)
16 {
17 tn2 = new TreeNode(dt.Rows[i][1].ToString(), dt.Rows[i][0].ToString()); // 生成需要绑定的节点
18 tn.ChildNodes.Add(tn2); // 增加子节点
19 BindChild(Degree + 1, tn2); // 循环绑定子节点
20 flag = true; // 有子节点
21 }
22 if (!flag) // 当没有叶子节点(最底层的节点)时, 则添加超级链接
23 {
24 tn.NavigateUrl = "http://www.baidu.com";
25 tn.Target = "_blank";
26 }
27 // 销毁占用内存的空间
28 dt.Dispose();
29 ds.Dispose();
30 return flag;
31 }

绑定TreeView树

 1         /// <summary>
2 /// 绑定TreeView树 1--treeview的节点ID
3 /// </summary>
4 /// <param name="tv"></param>
5 private void BindTree(TreeView tv)
6 {
7 tv.Nodes.Clear(); // 初始化TreeView
8
9 TreeNode tn = new TreeNode();
10 DataSet ds = new DataSet(); // 获取子节点
11 getNode(1, "00", ref ds); // 获取一级节点
12 DataTable dt = ds.Tables[0]; // DataTable的读取速度快与DataSet;
13
14 int len = dt.Rows.Count;
15 for (int i = 0; i < len; i++) // 绑定节点TreeNode
16 {
17 tn = new TreeNode(dt.Rows[i][1].ToString(), dt.Rows[i][0].ToString()); //
18 if (!BindChild(1, tn)) // 当无子节点的时候,链接百度,也可以设置ViewState的值
19 {
20 tn.NavigateUrl = "http://www.baidu.com";
21 tn.Target = "_blank";
22 }
23 tv.Nodes.Add(tn); // 将节点添加到原来的TreeView中
24 }
25 // 销毁占用内存的空间
26 dt.Dispose();
27 ds.Dispose();
28 }

心得体会 :  也许这个效率很低,不过这个也是我自己写的简单的一部分。整个过程跟DropDownList很像,可以参照添加DropDownList的方法添加;

设计思路 :

首先,先写出关于获取节点的方法, 里面有只需要三个值 当前的模块等级, 模块ID, 模块名字

第二,绑定一级栏目(一级栏目的绑定相对于子节点较为特殊),所以单独写一个方法,当然写成一个方法也是可以。边绑定要判断是否有子节点,如果无子节点则绑定超级链接。

第三,绑定二级栏目、跟一级栏目的获取差不多,

第四, 第一次显示时,模块只需要显示一级模块 即(tree1.ExpandDepth=0)。其他模块默认隐藏

替换方法 : 如果第一次读取数据库时生成XML文件,这样是否可以加快速度,可以减缓对数据库的读取速度。使用XML的方法生成树图,以后再学习.Ending.

关于TreeView的实例的更多相关文章

  1. 完整的treeview菜单实例

    以下是我用treeview控件按部门和员工显示设备领用情况代码. Option Compare Database    Dim rec As New ADODB.Recordset    Dim re ...

  2. 基于bootstrap的jQuery多级列表树插件 treeview

    http://www.cnblogs.com/mfc-itblog/p/5233453.html http://www.htmleaf.com/jQuery/Menu-Navigation/20150 ...

  3. bootstrap-treeview

    简要教程 bootstrap-treeview是一款效果非常酷的基于bootstrap的jQuery多级列表树插件.该jQuery插件基于Twitter Bootstrap,以简单和优雅的方式来显示一 ...

  4. 前端动态菜单-bootstrap-treeview

    一.bootstrap-treeview 官网 Demo bootstrap-treeview是一款效果非常酷的基于bootstrap的jQuery多级列表树插件.该jQuery插件基于Twitter ...

  5. 基于bootstrap的jQuery多级列表树插件

    简要教程 bootstrap-treeview是一款效果非常酷的基于bootstrap的jQuery多级列表树插件.该jQuery插件基于Twitter Bootstrap,以简单和优雅的方式来显示一 ...

  6. PythonQt进阶

    本文介绍PythonQt和qt之间是如何进行交互操作的 例子是以Qt的TreeView为实例进行介绍 在该例子中,TreeItem不是从Qt中进行的继承,这样的类如果要和Python进行交互,首先需要 ...

  7. bootstrap-treeview中文API 以及后台JSON数据处理

    bootstrap-treeview   简要教程 bootstrap-treeview是一款效果非常酷的基于bootstrap的jQuery多级列表树插件.该jQuery插件基于Twitter Bo ...

  8. BootStrap-treeview 参考

    简要教程 bootstrap-treeview是一款效果非常酷的基于bootstrap的jQuery多级列表树插件.该jQuery插件基于Twitter Bootstrap,以简单和优雅的方式来显示一 ...

  9. bootStrap-treeview插件

    简要教程 bootstrap-treeview是一款效果非常酷的基于bootstrap的jQuery多级列表树插件.该jQuery插件基于Twitter Bootstrap,以简单和优雅的方式来显示一 ...

随机推荐

  1. 强哥jQuery学习笔记

    js对象: 1.js内置对象 2.js元素对象 3.jquery对象 js特效: 1.js元素对象 2.jQuery对象 jQuery学习: 1.核心函数 2.选择器 3.筛选 4.文档处理 5.属性 ...

  2. VMware vCenter重置web console SSO登录密码

    On a Windows Platform Services Controller or vCenter Server with Embedded Platform Services Controll ...

  3. 011.Ansible条件语句

    一 简介 在有的时候play的结果依赖于变量.fact或者是前一个任务的执行结果,或者有的时候,我们会基于上一个task执行返回的结果而决定如何执行后续的task.这个时候就需要用到条件判断. 条件语 ...

  4. SSH工作过程简介和SSH协议算法集简介

    SSH简介 SSH是Secure Shell(安全外壳)的简称,是一种在不安全的网络环境中,通过加密机制和认证机制,实现安全的远程访问以及文件传输等业务的网络安全协议. SSH协议采用了典型的客户端/ ...

  5. Day029 JDK8中新日期和时间API (二)

    # JDK8中新日期和时间API (二) Instant介绍 Instant:时间线上的一个瞬时点. 这可能被用来记录应用程序中的事件时间 戳. 在处理时间和日期的时候,我们通常会想到年,月,日,时, ...

  6. 也谈如何写一个Webserver(三)

    在上一篇里,我介绍了如何应用socket和epoll来组织和管理从客户端(如,浏览器)传入的连接,通过设置非阻塞连接让Webserver有更好的性能. 下面,我介绍一下在我写的Webserver Ma ...

  7. 对狂神的shiro的学习总结

    1.shiro的10分钟快速开始 导入依赖 新建一个普通的maven项目,然后new一个hello-shiro(moudle)作为第一个测试项目 具体框架如下: 导入对应的依赖在pom.xml文件里 ...

  8. Django(46)drf序列化类的使用(ModelSerializer)

    前言 我们上篇文章使用到了Serializer类,可能有小伙伴说太过复杂,那么本篇就为大家带来更加简便的序列化类ModelSerializer ModelSerializer 先来看下ModelSer ...

  9. Python单元测试简介及Django中的单元测试

    Python单元测试简介及Django中的单元测试 单元测试负责对最小的软件设计单元(模块)进行验证,unittest是Python自带的单元测试框架. 单元测试与功能测试都是日常开发中必不可少的部分 ...

  10. GO语言常用标准库03---time包

    package main import ( "fmt" "time" ) func main021() { nowTime := time.Now() fmt. ...