webform 创建树
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
namespace WebApplication4
{
public partial class WebForm1 : System.Web.UI.Page
{
DataTable _dt = new DataTable();
protected void Page_Load(object sender, EventArgs e)
{
_dt.Columns.Add("code");
_dt.Columns.Add("parentCode");
_dt.Columns.Add("name");
DataRow dr=_dt.NewRow();
dr[0]="01";
dr[1]="0";
dr[2]="顶层1";
_dt.Rows.Add(dr);
dr = _dt.NewRow();
dr[0] = "011";
dr[1] = "01";
dr[2] = "子层1";
_dt.Rows.Add(dr);
dr = _dt.NewRow();
dr[0] = "012";
dr[1] = "01";
dr[2] = "子层2";
_dt.Rows.Add(dr);
dr = _dt.NewRow();
dr[0] = "02";
dr[1] = "0";
dr[2] = "顶层2";
_dt.Rows.Add(dr);
dr = _dt.NewRow();
dr[0] = "021";
dr[1] = "02";
dr[2] = "子层1";
_dt.Rows.Add(dr);
dr = _dt.NewRow();
dr[0] = "022";
dr[1] = "02";
dr[2] = "子层2";
_dt.Rows.Add(dr);
dr = _dt.NewRow();
dr[0] = "0221";
dr[1] = "022";
dr[2] = "子子层1";
_dt.Rows.Add(dr);
BuildTree(null, _dt);
}
/// <summary>
/// 绑定树
/// </summary>
/// <param name="tn"></param>
private void BuildTree(TreeNode tn, DataTable dtDept)
{
int i;
// 空节点时创建根节点,父ID为0的当作根节点
if (tn == null)
{
this.TreeView1.Nodes.Clear();
for (i = 0; i < dtDept.Rows.Count; i++)
{
if (dtDept.Rows[i]["parentCode"].ToString() == "0")
{
TreeNode tmp = new TreeNode(dtDept.Rows[i]["name"].ToString());
tmp.Value = dtDept.Rows[i]["code"].ToString();
tmp.ToolTip = dtDept.Rows[i]["parentCode"].ToString();
tmp.Checked = true;
TreeView1.Nodes.Add(tmp);
}
}
// 循环递归创建树
for (i = 0; i < TreeView1.Nodes.Count; i++)
{
BuildTree(TreeView1.Nodes[i],dtDept);
}
}
else // 节点非空为递归调用
{
for (i = 0; i < dtDept.Rows.Count; i++)
{
if (tn.Value.ToString() == dtDept.Rows[i]["parentCode"].ToString())
{
TreeNode tmp = new TreeNode(dtDept.Rows[i]["name"].ToString());
tmp.Value = dtDept.Rows[i]["code"].ToString();
tmp.ToolTip = dtDept.Rows[i]["parentCode"].ToString();
tn.ChildNodes.Add(tmp);
}
}
for (i = 0; i < tn.ChildNodes.Count; i++)
{
BuildTree(tn.ChildNodes[i],dtDept);
}
}
}
protected void TreeView1_SelectedNodeChanged(object sender, EventArgs e)
{
this.Label1.Text = TreeView1.SelectedValue;
ScriptManager.RegisterStartupScript(UpdatePanel1, this.GetType(), "updatePanel1show", "change_css('" + Label1.Text + "')", true);
TreeView1.ExpandAll();
}
}
}
webform 创建树的更多相关文章
- 使用Ext 创建树
ext使用的是ext3.4.0版本 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> < ...
- WebForm中创建树节点TreeNode
Tree: namespace ECTECH.NorthSJ.Web.SysData { public partial class testTree : BasePage { ; protected ...
- 用数据表创建树_delphi教程
数据库结构:字段 类型ID 整型 索引(无重复)name 文本father 整型 //tree初始化procedure TForm1.FormActivate(Sender: TObject);var ...
- 遍历json创建树状表(首先的前提条件是要引入jquery的jquery treeTable插件)
"root":{ "children":[ { "name":"AA", "children":[ ...
- Qt 使用大神插件快速创建树状导航栏
前言 本博客仅仅记录自己的采坑过程以及帮助网友避坑,方便以后快速使用自定义控件,避免重复出错. 下载插件 大神 Github Qt 自定义控件项目地址:https://github.com/feiya ...
- SAP CRM 树视图(TREE VIEW)
树视图可以用于表示数据的层次. 例如:SAP CRM中的组织结构数据可以表示为树视图. 在SAP CRM Web UI的术语当中,没有像表视图(table view)或者表单视图(form view) ...
- HTML5 程序设计 - 使用HTML5 Canvas API
请你跟着本篇示例代码实现每个示例,30分钟后,你会高喊:“HTML5 Canvas?!在哥面前,那都不是事儿!” 呵呵.不要被滚动条吓到,很多都是代码和图片.我没有分开写,不过上面给大家提供了目录,方 ...
- 二叉树的创建和遍历(C版和java版)
以这颗树为例:#表示空节点前序遍历(根->左->右)为:ABD##E##C#F## 中序遍历(左->根->右)为:#D#B#E#A#C#F# 后序遍历(左->右-> ...
- JavaScript高级编程 (1) - javscript是什么
<重温javascript>这是一系列 javascript 的学习笔记,部分内容摘自书本或者网络,我这里只是基于自己的理解进行了梳理整理. 一个完整的 javscript 实现是由以下3 ...
随机推荐
- python中lambda函数
1.lambda函数使用如下: lambda语句中,冒号前是参数,可以有多个,用逗号隔开,冒号右侧的是返回值 >>> g=lambda x,y:x*y>>> g(4 ...
- VS2010 添加服务引用以后点不出引用服务的命名空间
声明:本次我遇到的仅是这类情况中的其中一个个例,不要拘泥于些噢! 问题描述: 1.我建了一个新项目,不引用服务前是好的,可以打点点出任何已有有命名空间,但是引用服务以后就是点不出服务的命名空间. 2. ...
- jfinal 基本应用 --定时任务 QuartzPlugin
jfinal 的定时器的使用: 项目中使用的maven管理器 1.导入要使用的包 2.添加Job类 配置参数 这个配置是jfinal-quartz 包中带的默认文档,即是默认加载的文档(其中还有一个q ...
- Positive-definite kernel
Definition Let be a sequence of (complex) Hilbert spaces and be the bounded operators from Hi to Hj. ...
- js面向对象组件
1.包装对象 <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" ...
- Linux摄像头驱动学习之:(四)UVC-摄像头驱动框架分析
UVC: USB Video ClassUVC驱动:drivers\media\video\uvc\ uvc_driver.c分析:1. usb_register(&uvc_driver.dr ...
- ios中通知的简单使用
通知的机制是一对多,而block和delegate的机制是一对一,通知是好用,但小伙伴么要记得通知比较耗性能哦~~~ 谁要发送消息,谁就发出通知,谁要接受消息,谁就销毁通知. 下面直接来看代码: // ...
- 另一种图片上传 jquery.fileupload.js
今天遇到另外一种上传图片方法 用jquery.fileupload.js <input type="file" name="file[]" multipl ...
- angular 国际化
今天mentor说让我看看angular国际化的问题,我看了看,发现这个帖子很有价值,但是手头上还有好几个issue没有解决,所以就先考皮在这将连接,解决完这几个bug我再去细细研究这个问题, htt ...
- 同域名下PC与移动端自动识别跳转
输入相同域名,在pc端和移动端会出现不同的页面效果,一种是用栅格系统实现自适应,更多的是设计两套不同的模板和两个二级域名或者一个主域名和一个二级域名(就是有区别就可以了); js代码判断浏览器的用户代 ...