前台代码 (只需要有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. TODO不实现会报错

    kotlin.NotImplementedError: An operation is not implemented: Not yet implemented 会发生--当你 override fu ...

  2. Django中的中英文切换

    setting.py文件中 其中 zh-Hans是简体中文 zh-Hant是繁体中文 所以更改setttings.py 下 LANGUAGE_CODE = 'zh-Hans'即可 # 英文 LANGU ...

  3. 太赞了!Python竟可以轻松实现音频格式无损转换

    大家好,我是辰哥 辰哥在平时处理音频格式的时候,需要去下载各种音频处理软件(专业一点的软件还要收费),掌握Python技术的我们,知道Python是万能的(哈哈哈,开个玩笑).今天辰哥就来教大家用Py ...

  4. 『动善时』JMeter基础 — 31、JMeter中BeanShell断言详解

    目录 1.BeanShell简介 2.Beanshell的内置变量和方法 3.BeanShell断言界面详解 4.BeanShell断言的使用 (1)测试计划内包含的元件 (2)登陆接口请求界面内容 ...

  5. Win7 64 + mysql5.6.24(.zip) 不知道root密码的情况下重设密码

    解决方式 第一步:在运行(常常在附件中)里输出cmd,右键以系统管理员身份登陆: 第二步:停止mysql服务,命令为:net stop mysql  注意,若不行将当前目录切换到mysql\bin目录 ...

  6. curl 常用操作总结

    前言 curl 是一个强大的命令行工具,支持 HTTP, HTTPS, SCP 等多种协议,本文主要总结一下其常用的功能,方便及时查阅. curl --version curl 7.68.0 (x86 ...

  7. 目标检测中特征融合技术(YOLO v4)(下)

    目标检测中特征融合技术(YOLO v4)(下) ASFF:自适应特征融合方式 ASFF来自论文:<Learning Spatial Fusion for Single-Shot Object D ...

  8. 深度学习框架:GPU

    深度学习框架:GPU Deep Learning Frameworks 深度学习框架通过高级编程接口为设计.训练和验证深度神经网络提供了构建块.广泛使用的深度学习框架如MXNet.PyTorch.Te ...

  9. Nsight Compute Profilier 分析

    profiler报告包含每次内核启动分析期间收集的所有信息.在用户界面中,它包含一个包含常规信息的标题,以及用于在报告页面或单个收集的启动之间切换的控件.默认情况下,报告以选定的详细信息页面开始. 页 ...

  10. 单核性能强悍,Core i3 这次又要“默秒全”?

    单核性能强悍,Core i3 这次又要"默秒全"? 在 Intel 历代酷睿处理器中,定位主流级的 Core i3 一直以超高性价比.低功耗.低发热的特点受到广大用户的青睐,在市场 ...