递归实现DropDownList层级
.NET下拉框DropDownList层级实现
这也算是第一篇博客吧,技术比较菜,写得不好,希望各位博友见谅哈,多多提提意见。
今天做电商网站新闻添加的时候,下拉框选择新闻类别觉得太长,又无法定位其准确级别,让人甚是苦恼,于是想做一个层级的下拉框,刚开始的时候想到了用递归树去实现,之前写过递归树,觉得应该可以,便试了一下,递归树代码如下:
#region 递归添加下拉框的值 参数ParentID为树的最大父结点
public void AddTree(int ParentID, ListItem pNode)
{
//过滤ParentID,得到当前的所有子节点 ParentID为父节点ID
(this.ViewState["DataView_Tree"] as DataTable).DefaultView.RowFilter = "[ParMenuListId] = " + ParentID; //循环递归
foreach (DataRowView Row in (this.ViewState["DataView_Tree"] as DataTable).DefaultView)
{
//声明节点
ListItem li = new ListItem();
if (pNode == null)
{
//添加根节点
li.Text = Row["MenuListName"].ToString();
li.Value = Row["MenuListId"].ToString();
ddlParMenu.Items.Add(li);
AddTree(Int32.Parse(Row["MenuListId"].ToString()), li); //递归
}
else
{
//添加当前节点的子节点
li.Text = "├—" + Row["MenuListName"].ToString();
li.Value = Row["MenuListId"].ToString();
ddlParMenu.Items.Add(li);
AddTree(Int32.Parse(Row["MenuListId"].ToString()), li); //递归
}
}
}
#endregion
注释已经写的很清楚了,不用我多说了吧,调用方法如下:
this.ViewState["DataView_Tree"] = DbHelperSQL.Query(@"select MenuListId,ParMenuListId,MenuListName from RY_MenuList").Tables[];//屏蔽快速通道设置
AddTree(, (ListItem)null);
运行结果,确实可以出来,运行结果如图所示:
我在数据库再加一列之后,加载测试全新2节点下,显示
可以看到,虽然测试权限2在测试权限3下,但是依旧会出现和他同级的情况,查看代码可知:
//声明节点
ListItem li = new ListItem();
if (pNode == null)
{
//添加根节点
li.Text = Row["MenuListName"].ToString();
li.Value = Row["MenuListId"].ToString();
ddlParMenu.Items.Add(li);
AddTree(Int32.Parse(Row["MenuListId"].ToString()), li); //递归
}
else
{
//添加当前节点的子节点
li.Text = "├—" + Row["MenuListName"].ToString();
li.Value = Row["MenuListId"].ToString();
ddlParMenu.Items.Add(li);
AddTree(Int32.Parse(Row["MenuListId"].ToString()), li); //递归
}
参考上面递归代码不难看出,根节点加载没有问题,但是子节点,加载永远只有else,就是说,不管多少级,都走else,不会延伸出别的,想过通过定义级别来实现,但又要用到swicth来实现,太多的话,反而实现不了,扩展性不好,于是,网上找了一下资料,用了也是递归方式,跟这个也差不多,代码如下:
/// <summary>
/// 绑定下拉框(分层级)
/// </summary>
/// <param name="dt">绑定的数据源</param>
/// <param name="parentId">上一级的ID名称(数据列名称)</param>
/// <param name="colId">下拉框值</param>
/// <param name="colName">下拉框显示文本</param>
/// <param name="drs">顶级集合</param>
/// <param name="ddl">下拉框ID</param>
/// <param name="leveStr">层级的前缀</param>
/// <param name="nextStr">多层级的前缀</param>
protected void GetChild(DataTable dt, string parentId, string colId, string colName, DataRow[] drs, DropDownList ddl, string leveStr, string nextStr)
{
foreach (DataRow dr in drs)
{
string txt = dr[colName].ToString();
if (leveStr.Length != )
{
txt = leveStr + dr[colName].ToString();
}
ddl.Items.Add(new ListItem(txt, dr[colId].ToString()));
DataRow[] cdrs = dt.Select("ParMenuListId="+dr[colId]);
if (cdrs.Length != )
{
string nextLevelStr = leveStr.Insert(, nextStr);
//string nextLevelStr = leveStr.Insert(0, "├");
GetChild(dt, parentId, colId, colName, cdrs, ddl, nextLevelStr, nextStr);
}
}
}
这段代码调用方法:
DataTable dt = DbHelperSQL.Query("select MenuListId,ParMenuListId,MenuListName from RY_MenuList").Tables[];
DataRow[] dr = dt.Select("ParMenuListId=0");
GetChild(dt, "", "MenuListId", "MenuListName", dr, ddlParMenu, "—", "—");
完成之后,运行结果如图所示:
此处实现了多层级的表现方式,满足需求,可以无限级,至于前缀可以更改的。
致辞,多层级下拉框已经完毕,欢迎各位博友点评。
递归实现DropDownList层级的更多相关文章
- goroutine 加 channel 代替递归调用,突破递归调用的层级限制
package main import ( "fmt" "github.com/davecgh/go-spew/spew" "github.com/B ...
- 数据库的小案例(三):用递归实现TreeView层级显示
从这个小案例我学到了不少知识.这些无论如何无法从书里得来.正所谓实践出真知,学习编程需要大量实践这句话永不过时. 首先:好的代码和坏的代码带来的性能上的差异很明显.好的策略可以让你的程序运行速度大大加 ...
- c#通用递归生成无限层级树
NewsType结构: Id ParentId Name children(List<NewsType>) public void LoopToAppendChildren(List< ...
- json list数据递归生成树状层级JSON
<!DOCTYPE html> <html> <head> <script> var data=[ {"id":"aaa& ...
- js list数据 转 树状 层级 JSON,递归生成树状 层级 JSON
<!DOCTYPE html> <html> <head> <script> var data=[ {"id":"aaa& ...
- PHP使用递归按层级查找数据
今天主要介绍一下使用递归来按层级查找数据.原理挺简单的,主要是通过父级id一级一级的循环查找子级,使用PHP循环代码也很容易实现,不过如果层级越多,PHP重复代码也越多,这时可以使用递归来实现这功能. ...
- SQL Server中CTE的另一种递归方式-从底层向上递归
SQL Server中的公共表表达式(Common Table Expression,CTE)提供了一种便利的方式使得我们进行递归查询.所谓递归查询方便对某个表进行不断的递归从而更加容易的获得 ...
- JavaEE基础(二十三)/递归
1.File类递归练习(统计该文件夹大小) 需求:1,从键盘接收一个文件夹路径,统计该文件夹大小 2.File类递归练习(删除该文件夹) 需求:2,从键盘接收一个文件夹路径,删除该文件夹 3.File ...
- 菜鸟笔记:node.js+mysql中将JSON数据构建为树(递归制作树状菜单数据接口)
初学Web端开发,今天是第一次将所学做随笔记录,肯定存在多处欠妥,望大家海涵:若有不足,望大家批评指正. 进实验室后分配到的第一个项目,需要制作一个不确定层级树形菜单的数据接口,对于从来没实战编过程的 ...
随机推荐
- 04.Java基础语法
一.Java源程序结构与编程规范 一个完整的Java源程序应该包含下列部分 package语句,至多一句,必须放在源程序第一句 import语句,没有或者若干句,必须放在所有类定义前 public c ...
- 没有国产主机,怎么开发:交叉编译和QEMU虚拟机
1. 背景 近期国产化的趋势越来越浓,包括国产操作系统.国产CPU等.时隔十多年,QQ for Linux也更新了.做为软件开发人员,"有幸"也需要适配国产化.至于国产化的意义等就 ...
- Jmeter使用beanshell对数据进行加密传输
首先,来看一下接口签名加密规则 1.需要参于签名的参数: a. 在请求参数列表中,除去 cliSign 参数外,其他需要使用到的参数皆是要签名的参数. 2.生成签名字符串 a. 没有值的参数无需传递, ...
- 分享一个我自己做的 Excel 万年历
下载链接在此. 纯 Excel 公式实现,带农历,可自定义节日.配色. 带有紧凑日历和记事日历两种日历,均可直接 Ctrl+P 打印,且打印时不带有顶部的控制栏.
- 检查*.ldf为何这么大
testdb,只是个测试用文件,备份时突然发现*.ldf怎么这么大,当硬盘不要花银子买啊......--可随意删除...,有空再检查,累了休息... 如批量生成数据.或导入那个来自MySQL的Empl ...
- sorted排序
sorted(['bob', 'about', 'Zoo', 'Credit']) # ['Credit', 'Zoo', 'about', 'bob'] ''' 默认情况下,对字符串排序,是按照AS ...
- ca76a_c++_流文件打开输入输出文件模式p773
/*ca76a_c++_流文件打开输入输出文件模式利用文件流打开文件进行输入与输出时的选项in.out.app(附加模式).ate((end)文件打开后,定于文件结尾).trunc(裁剪).binar ...
- 使用DragonFly进行智能镜像分发
Dragonfly 是一款基于 P2P 的智能镜像和文件分发工具.它旨在提高文件传输的效率和速率,最大限度地利用网络带宽,尤其是在分发大量数据时,例如应用分发.缓存分发.日志分发和镜像分发. 在阿里巴 ...
- .Net Core微服务入门全纪录(六)——EventBus-事件总线
前言 上一篇[.Net Core微服务入门全纪录(五)--Ocelot-API网关(下)]中已经完成了Ocelot + Consul的搭建,这一篇简单说一下EventBus. EventBus-事件总 ...
- 为Promise添加finally方法支持,把小程序函数变成promise函数
// 为Promise添加finally方法支持 Promise.prototype.finally = function (callback) { let P = this.constructo ...