用c#.net和sql先谢谢了!

解决方案 »

  1.   

    这样的功能模拟可以做出来
    参考
    http://dotnet.aspx.cc/WebDropDownList.aspxhttp://dotnet.aspx.cc/ShowDetail.aspx?id=C81AD80E-FC14-4FF8-85F3-16CC68811BD5
      

  2.   

    恐怕只能模拟了,dropdownlist不能做container的。
      

  3.   

    首先设计好数据库,假设数据库有三个字段Id,ParentId,Name。ParentId是树性结构必须的,就是节点的父节点id,假设跟节点id都是0。下面就可以绑定了!          思路应该很简单,就是先绑定根节点,再循环绑定子节点!父节点和子节点之间为了显示出层次结构,用空格格开,不过不是space键,没用的,必须用v1的特殊字符1。/// <summary>
      /// 绑定根节点
      /// </summary>
      void bindGroup()
      {
       DataTable dt =//获取所有节点
       if(dt.Rows.Count>0)
       {
        foreach(DataRow row in dt.Rows)
        {
         if(row["ParentId"].ToString().Trim()=="0")//绑定根节点
         {
          this.drpItGroup.Items.Add(new ListItem(row["Name"].ToString(),row["Id"].ToString()));
          this.bindDropChildItem(this.drpItGroup,dt,row["Id"].ToString(),1);
         }
        }
       }
      }
      /// <summary>
      /// 绑定子节点
      /// </summary>
      /// <param name="d"></param>
      /// <param name="dt"></param>
      /// <param name="id"></param>
      /// <param name="length"></param>
      void bindDropChildItem(DropDownList d,DataTable dt,string id,int length)
      {
       DataRow[] rows=dt.Select("ParentId='"+id+"'","Id DESC");//取出id子节点进行绑定
       for(int i=0;i<rows.Length;i++)
       {
        this.drpItGroup.Items.Add(new ListItem(this.SpaceLength(length)+rows[i]["Name"].ToString(),rows[i]["Id"].ToString()));
        this.bindDropChildItem(d,dt,rows[i]["Id"].ToString(),length+1);//空白数目加1
       }
      }
      /// <summary>
      /// 子节点前面的空白数
      /// </summary>
      /// <param name="i"></param>
      /// <returns></returns>
      string SpaceLength(int i)
      {
          string space="";
       for(int j=0;j<i;j++)
       {
        space+=" ";//注意这里的空白是智能abc输入法状态下的v11字符;
       }
       return space;
      }