转载笔记:DropDownList无限级分类(灵活控制显示形式)
主要使用递归实现,数据库结构:
最终样式:
2 {
3 if (!Page.IsPostBack)
4 {
5 BindDrpClass();
6 }
7 }
8 //绑定顶级分类
9 private void BindDrpClass()
10 {
11 Bll.Class classSystem = new Bll.Class();
12 DataTable dt = classSystem.GetClassList("").Tables[0];
13 ddlClass.Items.Clear();
14 ddlClass.Items.Add(new ListItem("添加根栏目","0"));
15 DataRow[] drs = dt.Select("ParentID= " + 0);
16
17 foreach (DataRow dr in drs)
18 {
19 string classid = dr["ClassID"].ToString();
20 string classname = dr["ClassName"].ToString();
21 //顶级分类显示形式
22 classname = "╋" + classname;
23
24 ddlClass.Items.Add(new ListItem(classname, classid));
25 int sonparentid = int.Parse(classid);
26 string blank = "├";
27 //递归子分类方法
28 BindNode(sonparentid, dt, blank);
29 }
30 ddlClass.DataBind();
31 }
32 //绑定子分类
33 private void BindNode(int parentid, DataTable dt, string blank)
34 {
35 DataRow[] drs = dt.Select("ParentID= " + parentid);
36
37 foreach (DataRow dr in drs)
38 {
39 string classid = dr["ClassID"].ToString();
40 string classname = dr["ClassName"].ToString();
41
42 classname = blank + classname;
43 ddlClass.Items.Add(new ListItem(classname, classid));
44
45 int sonparentid = int.Parse(classid);
46 string blank2 = blank + "─";
47
48 BindNode(sonparentid, dt, blank2);
49 }
50 }
源码下载:
http://files.cnblogs.com/chensubo/RecursionDemo.rar
改造过的函数
// <asp:DropDownList ID="editparentid" runat="server" ></asp:DropDownList>
/// <summary>
/// 加载页面
///</summary>
protected void Page_Load(object sender, EventArgs e)
{
BindDrpClass(editparentid);}
/// <summary>
/// 创建树
/// </summary>
public void BindDrpClass(DropDownList ddlClass)
{
DataTable dt = DbHelper.ExecuteDataset(SysConst.DBNAME_XIAOWU, "select * from NT_Clcs_ClientType").Tables[0];
ddlClass.Items.Clear();
ddlClass.Items.Add(new ListItem("添加根栏目", "0"));
DataRow[] drs = dt.Select("ParentID= " + 0);
foreach (DataRow dr in drs){
string classid = dr["Cc_ID"].ToString();
string classname = dr["Cc_Name"].ToString();
//顶级分类显示形式
classname = "╋" + classname; ddlClass.Items.Add(new ListItem(classname, classid));
int sonparentid = int.Parse(classid);
string blank = "├";
//递归子分类方法
BindNode(ddlClass, sonparentid, dt, blank);
}
editparentid.DataBind();
}
/// <summary>
/// 创建树结点
/// </summary>
private void BindNode(DropDownList ddlNode, int parentid, DataTable dt, string blank)
{
DataRow[] drs = dt.Select("ParentID= " + parentid);
foreach (DataRow dr in drs){
string classid = dr["Cc_ID"].ToString();
string classname = dr["Cc_Name"].ToString();
classname = blank + classname;
ddlNode.Items.Add(new ListItem(classname, classid));
int sonparentid = int.Parse(classid);
string blank2 = blank + "─";
BindNode(ddlNode,sonparentid, dt, blank2);
}
}
二次改造做成一个通用的类 调用 如: new DrpGradingList("select * from dbo.NT_Clcs_ClientType ", "Cc_Name", "Cc_ID", defValue).BindDrpClass(ddl);
/// <summary>
/// DropDownList 树形显示
/// </summary>
public class DrpGradingList
{
private string Sql = "";
private string Text = "";
private string Value = "";
private string defValue = "";
private string parentId = "ParentID";
/// <summary>
/// DropDownList 树形显示
/// </summary>
/// <param name="sql">SQL语句</param>
/// <param name="text">显示的文本( 数据库字段)</param>
/// <param name="value">显示的文本对应的值( 数据库字段)</param>
public DrpGradingList(string sql, string text, string value, string defvalue)
{
this.Sql = sql;
this.Text = text;
this.Value = value;
this.defValue = defvalue;
}
/// <summary>
/// DropDownList 树形显示
/// </summary>
/// <param name="sql">SQL语句</param>
/// <param name="text">显示的文本( 数据库字段)</param>
/// <param name="value">显示的文本对应的值( 数据库字段)</param>
public DrpGradingList(string sql, string text, string value, string defvalue,string pid)
{
this.Sql = sql;
this.Text = text;
this.Value = value;
this.defValue = defvalue;
this.parentId = pid;
}
/// <summary>
/// 创建树
/// </summary>
public void BindDrpClass(DropDownList ddlClass)
{
DataTable dt = DbHelper.ExecuteDataset(SysConst.DBNAME_XIAOWU, Sql).Tables[0];
ddlClass.Items.Clear();
ddlClass.Items.Add(new ListItem("顶级栏目", "0"));
DataRow[] drs = dt.Select(""+this.parentId+"= " + 0);
foreach (DataRow dr in drs)
{
string classid = dr[this.Value].ToString();
string classname = dr[this.Text].ToString();
//顶级分类显示形式
classname = "╋" + classname; ListItem itme = new ListItem();
itme.Text=classname;
itme.Value=classid;
if (itme.Value.Equals(this.defValue))
itme.Selected = true; ddlClass.Items.Add(itme);
int sonparentid = int.Parse(classid);
string blank = "├";
//递归子分类方法
BindNode(ddlClass, sonparentid, dt, blank);
}
ddlClass.SelectedIndex = ddlClass.Items.IndexOf(ddlClass.Items.FindByValue(this.defValue));
ddlClass.DataBind();
}
/// <summary>
/// 创建树 ddlClass.Items.Add(new ListItem("顶级栏目", "0"));
/// </summary>
public void BindDrpClass(DropDownList ddlClass, bool defItem)
{
DataTable dt = DbHelper.ExecuteDataset(SysConst.DBNAME_XIAOWU, Sql).Tables[0];
ddlClass.Items.Clear();
if (defItem){
ddlClass.Items.Add(new ListItem("顶级栏目", "0"));
}
DataRow[] drs = dt.Select("" + this.parentId + "= " + 0);
foreach (DataRow dr in drs)
{
string classid = dr[this.Value].ToString();
string classname = dr[this.Text].ToString();
//顶级分类显示形式
classname = "╋" + classname; ListItem itme = new ListItem();
itme.Text = classname;
itme.Value = classid;
if (itme.Value.Equals(this.defValue))
itme.Selected = true; ddlClass.Items.Add(itme);
int sonparentid = int.Parse(classid);
string blank = "├";
//递归子分类方法
BindNode(ddlClass, sonparentid, dt, blank);
}
ddlClass.SelectedIndex = ddlClass.Items.IndexOf(ddlClass.Items.FindByValue(this.defValue));
ddlClass.DataBind();
}
public void BindDrpClass(DropDownList ddlClass, bool defItem,string parentIdefVale)
{
if (parentIdefVale.Length == 0) parentIdefVale = "0";
DataTable dt = DbHelper.ExecuteDataset(SysConst.DBNAME_XIAOWU, Sql).Tables[0];
ddlClass.Items.Clear();
if (defItem)
{
ddlClass.Items.Add(new ListItem("顶级栏目", "0"));
}
DataRow[] drs = dt.Select("" + this.parentId + "= " + parentIdefVale);
foreach (DataRow dr in drs)
{
string classid = dr[this.Value].ToString();
string classname = dr[this.Text].ToString();
//顶级分类显示形式
classname = "╋" + classname; ListItem itme = new ListItem();
itme.Text = classname;
itme.Value = classid;
if (itme.Value.Equals(this.defValue))
itme.Selected = true; ddlClass.Items.Add(itme);
int sonparentid = int.Parse(classid);
string blank = "├";
//递归子分类方法
BindNode(ddlClass, sonparentid, dt, blank);
}
ddlClass.SelectedIndex = ddlClass.Items.IndexOf(ddlClass.Items.FindByValue(this.defValue));
ddlClass.DataBind();
}
/// <summary>
/// 创建树结点
/// </summary>
private void BindNode(DropDownList ddlNode, int parentid, DataTable dt, string blank)
{
DataRow[] drs = dt.Select(""+this.parentId+"= " + parentid);
foreach (DataRow dr in drs)
{
string classid = dr[this.Value].ToString();
string classname = dr[this.Text].ToString();
classname = blank + classname; ListItem itme = new ListItem();
itme.Text = classname;
itme.Value = classid;
if (itme.Value.Equals(this.defValue))
itme.Selected = true;
ddlNode.Items.Add(itme); int sonparentid = int.Parse(classid);
string blank2 = blank + "─";
BindNode(ddlNode, sonparentid, dt, blank2);
}
}
}
RadTreeView控件 应用:
<telerik:RadTreeView runat="server" ID="RadTreeView2" Skin="Office2007"
Width="300px" Height="450px" CheckBoxes="True" DataTextField="ParentID"
TriStateCheckBoxes="False">
</telerik:RadTreeView>
AddTree("0", this.RadTreeView2.Nodes); public void AddTree(string fdm, RadTreeNodeCollection nodes)
{
DataTable dt = DbHelper.ExecuteDataset(SysConst.DBNAME_XIAOWU, "select * from NT_Clcs_Village where ParentID=" + fdm + "").Tables[0]; foreach (DataRow dr in dt.Rows)
{
string classid = dr["Cv_ID"].ToString();
string classname = dr["Cv_Name"].ToString(); RadTreeNode main = new RadTreeNode();
main.Text = classname;
main.Value = classid;
nodes.Add(main);
AddTree(classid, main.Nodes);
}
}
其它:
dropDownList.SelectedIndex=dropDownList.Items.IndexOf(dropDownList.Items.FindByText(entityBase.Bugstatus));
MVC树形:
使用: @Html.DropDownList("ddlXzqy", ViewData["ddlXzqy"] as IEnumerable<SelectListItem>)
/// <summary> /// 创建树 /// </summary> public void BindDrpClass(Guid selectId) { var list = repo.GetXzqyRootsList(); List<SelectListItem> selitem = new List<SelectListItem>(); foreach ( var item in list) { //顶级分类显示形式 if (selectId == item.ID) { selitem.Add( new SelectListItem { Text = "╋" + item.Name, Value = item.ID.ToString(), Selected = true }); this .ViewData[ "selected" ] = item.ID.ToString(); } else { selitem.Add( new SelectListItem { Text = "╋" + item.Name, Value = item.ID.ToString() }); } //递归子分类方法 string blank = "├" ; BindNode(item.ID, blank, selitem, selectId); } selitem.Insert(0, new SelectListItem { Text = "==行政区域==" , Value = "-1" }); ViewData[ "ddlXzqy" ] = selitem; } private void BindNode(Guid parentid, string blank, List<SelectListItem> selitem, Guid selectId) { var list = repo.GetXzqyChildList(parentid); foreach ( var item in list) { if (selectId == item.ID) { selitem.Add( new SelectListItem { Text = blank + item.Name, Value = item.ID.ToString(), Selected = true }); this .ViewData[ "selected" ] = item.ID.ToString(); } else { selitem.Add( new SelectListItem { Text = blank + item.Name, Value = item.ID.ToString() }); } string blank2 = blank + "─" ; BindNode(item.ID, blank2, selitem, selectId); } } |
转载笔记:DropDownList无限级分类(灵活控制显示形式)的更多相关文章
- C#无限级分类递归显示示例
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="RoleDemo20150305 ...
- 2强类型DataSet (2011-12-30 23:16:59)转载▼ 标签: 杂谈 分类: Asp.Net练习笔记 http://blog.sina.com.cn/s/blog_9d90c4140101214w.html
强类型DataSet (2011-12-30 23:16:59) 转载▼ 标签: 杂谈 分类: Asp.Net练习笔记 using System; using System.Collections.G ...
- 强类型DataSet (2011-12-30 23:16:59)转载▼ 标签: 杂谈 分类: Asp.Net练习笔记 http://blog.sina.com.cn/s/blog_9d90c4140101214w.html
强类型DataSet (2011-12-30 23:16:59) 转载▼ 标签: 杂谈 分类: Asp.Net练习笔记 using System; using System.Collections.G ...
- MVC无限级分类02,增删改查
继上一篇"MVC无限级分类01,分层架构,引入缓存,完成领域模型与视图模型的映射",本篇开始MVC无限级分类的增删改查部分,源码在github. 显示和查询 使用datagrid显 ...
- PHP递归实现无限级分类
在一些复杂的系统中,要求对信息栏目进行无限级的分类,以增强系统的灵活性.那么PHP是如何实现无限级分类的呢?我们在本文中使用递归算法并结合mysql数据表实现无限级分类. 在一些复杂的系统中,要求对信 ...
- mysql无限级分类
第一种方案: 使用递归算法,也是使用频率最多的,大部分开源程序也是这么处理,不过一般都只用到四级分类. 这种算法的数据库结构设计最为简单.category表中一个字段id,一个字段fid(父id).这 ...
- (实用篇)PHP递归实现无限级分类
在一些复杂的系统中,要求对信息栏目进行无限级的分类,以增强系统的灵活性.那么PHP是如何实现无限级分类的呢?我们在本文中使用递归算法并结合mysql数据表实现无限级分类. 在一些复杂的系统中,要求对信 ...
- PHP无限级分类-递归(不推荐)
[http://www.helloweba.com/view-blog-204.html] 在一些复杂的系统中,要求对信息栏目进行无限级的分类,以增强系统的灵活性.那么PHP是如何实现无限级分类的呢? ...
- STM32学习笔记(四)——串口控制LED(中断方式)
目录: 一.时钟使能,包括GPIO的时钟和串口的时钟使能 二.设置引脚复用映射 三.GPIO的初始化配置,注意要设置为复用模式 四.串口参数初始化配置 五.中断分组和中断优先级配置 六.设置串口中断类 ...
随机推荐
- 理解Web应用程序的代码结构和运行原理(3)
1.理解Web应用程序的运行原理和机制 Web应用程序是基于浏览器/服务器模式(也称B/S架构)的应用程序,它开发完成后,需要部署到Web服务器上才能正常运行,与用户交互的客户端是网页浏览器. 浏览器 ...
- PyCharm2018激活码
亲测可用: 来自:https://blog.csdn.net/u014044812/article/details/78727496
- Oracle表分区分为四种:范围分区,散列分区,列表分区和复合分区(转载)
一:范围分区 就是根据数据库表中某一字段的值的范围来划分分区,例如: 1 create table graderecord 2 ( 3 sno varchar2(10), 4 sname varcha ...
- CoreAnimation|动画
IOS开发UI篇--IOS动画(Core Animation)总结 - CSDN博客 iOS动画,绝对够分量! - 简书 iOS动画篇:UIView动画 - 简书 iOS动画开发之五--炫酷的粒子效果 ...
- JavaIO流(输入输出操作)
Java中执行输出和输入操作,需要通过IO流.例如最常见的System.out.println()就是一个输出流.IO流的类比较多,但核心体系就是由File. InputStream .OutputS ...
- 19-3-8Python中编码的进阶、文件操作初识、深浅copy
编码的进阶 ASCII:英文字母,数字,特殊符号,——> 二进制的对应关系 Str: 1个字符——> 1个字节 Unicode:万国码:世界上所有的文字与二进制的对应关系 1个字符——& ...
- 浅谈OSI七层网络模型和TCP/IP四层模型
OSI七层网络模型 OSI(Open System Interconnection)开放系统互连参考模型是国际标准化组织(ISO)制定的一个用于计算机或通信系统间互联的标准体系. OSI七层模型 功能 ...
- jquery购物车添加功能
<html> <head> <meta charset="UTF-8"> <title></title> <scr ...
- helloworld模块
环境: HelperA64开发板 Linux3.10内核 时间:2019.01.11 目标:编译helloword模块 1.当出先下面错误时候,查找问题 问题为Make的时候默认为PC-X86 ...
- 《Nginx高性能Web服务器》系列分享专栏
<Nginx高性能Web服务器>系列分享专栏 [作者:Poechant] Nginx是目前最流行的基于BSD-like协议.轻量级.高性能的HTTP服务器.反向代理服务器和电子邮件(SMT ...