热门标签 | 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



推荐阅读
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社区 版权所有