热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

DropDownList分层显示!

publicstaticvoidBindDropFatherItem(DropDownListDropDownList){DropDownList.Items.Clear();st
public static void BindDropFatherItem( DropDownList DropDownList )
    
{
        DropDownList.Items.Clear();
        
string strSql = "select * from Department";
        DataTable dt 
= DB.GetTable( strSql );//获取所有节点

        
//判断跟节点数量
        string strSql1 = "select count(*) from Department where  ParentID = 0";
        
int ParentCount = Convert.ToInt32( DB.ExecuteScalar( strSql1 ) );

        
if( dt.Rows.Count > 0 )
        
{
            
foreach( DataRow dr in dt.Rows )
            
{
                
if( ParentCount == 0 )
                
{
                    
if( dr[ "ParentID" ].ToString().Trim() == "0" )//绑定根节点   
                    {
                        DropDownList.Items.Insert( 
0"请选择" );
                        DropDownList.Items.Add( 
new ListItem( dr[ "DepName" ].ToString(), dr[ "DepID" ].ToString() ) );
                        BindDropChildItem( DropDownList, dt, dr[ 
"DepID" ].ToString(), 1 );
                    }

                }

                
else
                
{
                    
if( dr[ "ParentID" ].ToString().Trim() == "0" )//绑定根节点   
                    {                        
                        DropDownList.Items.Add( 
new ListItem( dr[ "DepName" ].ToString(), dr[ "DepID" ].ToString() ) );
                        BindDropChildItem( DropDownList, dt, dr[ 
"DepID" ].ToString(), 1 );
                    }

                }

                
            }

        }

    }

public static void BindDropChildItem( DropDownList DropDownList, DataTable dt, string id, int length )
    
{
        DataRow[] rows 
= dt.Select( "ParentID='" + id + "'""DepID  ASC" );//取出id子节点进行绑定   
        forint i &#61; 0; i < rows.Length; i&#43;&#43; )
        
{
            DropDownList.Items.Add( 
new ListItem( Department.SpaceLength( length ) &#43; rows[ i ][ "DepName" ].ToString(), rows[ i ][ "DepID" ].ToString() ) );
            BindDropChildItem( DropDownList, dt, rows[ i ][ 
"DepID" ].ToString(), length &#43; 1 );//空白数目加1   
        }

    }


    
//   子节点前面的空白数 
    public static string SpaceLength( int i )
    
{
        
string space &#61; "";
        
forint j &#61; 0; j < i; j&#43;&#43; )
        
{
            space 
&#43;&#61; "------";//分层显示字符&#xff1b;   
        }

        
return space;
    }
    

转:https://www.cnblogs.com/Magicam/archive/2008/06/07/1215616.html



推荐阅读
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 解决.net项目中未注册“microsoft.ACE.oledb.12.0”提供程序的方法
    在开发.net项目中,通过microsoft.ACE.oledb读取excel文件信息时,报错“未在本地计算机上注册“microsoft.ACE.oledb.12.0”提供程序”。本文提供了解决这个问题的方法,包括错误描述和代码示例。通过注册提供程序和修改连接字符串,可以成功读取excel文件信息。 ... [详细]
  • 本文介绍了在实现了System.Collections.Generic.IDictionary接口的泛型字典类中如何使用foreach循环来枚举字典中的键值对。同时还讨论了非泛型字典类和泛型字典类在foreach循环中使用的不同类型,以及使用KeyValuePair类型在foreach循环中枚举泛型字典类的优势。阅读本文可以帮助您更好地理解泛型字典类的使用和性能优化。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • 本文详细介绍了使用C#实现Word模版打印的方案。包括添加COM引用、新建Word操作类、开启Word进程、加载模版文件等步骤。通过该方案可以实现C#对Word文档的打印功能。 ... [详细]
  • 本文介绍了如何使用OpenXML按页码访问文档内容,以及在处理分页符和XML元素时的一些挑战。同时,还讨论了基于页面的引用框架的局限性和超越基于页面的引用框架的方法。最后,给出了一个使用C#的示例代码来按页码访问OpenXML内容的方法。 ... [详细]
  • ListBox.SelectedItem.Value可以获取当前被选中的一个值.但如果ListBox同时有多个值被选中应该如何获取这些值呢? ... [详细]
  • 浅谈Java8 的foreach跳出循环break/return_java
    这篇文章主要介绍了Java8的foreach跳出循环breakreturn,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 嵌套函数定义时先判断function_exists防止递归调用外部函数导致两次定义内部函数导致致命错误看一下PHP手册中是如何说的: ... [详细]
  • vlfilecopy(findfile(vllist>string(10811110311146103105102)))(vll的简单介绍
    本文目录一览:1、一段lisp代码求解释2、运 ... [详细]
author-avatar
xhl583337984
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有