DropDrownList控件递归绑定数据

现将表中的字段封装成属性:文件名(Demo_Area.cs)

using System;
using System.Data;
using System.Configuration;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;

/// <summary>
///Demo_Area 的摘要说明
/// </summary>
public class Demo_Area
{
 public Demo_Area()
 {
  //
  //TODO: 在此处添加构造函数逻辑
  //
 }
    private int id;
    private string name;
    private int pid;

    public int Pid
    {
        get { return pid; }
        set { pid = value; }
    }

    public string Name
    {
        get { return name; }
        set { name = value; }
    }

    public int Id
    {
        get { return id; }
        set { id = value; }
    }

}

 

页面中的代码段:

using System;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;
using System.Data.SqlClient;

public partial class _Default : System.Web.UI.Page
{

   //连接数据库
    private static string connstr = System.Configuration.ConfigurationManager.ConnectionStrings["ConnStr"].ToString();
    private static int intFlag;
    protected void Page_Load(object sender, EventArgs e)
    {
        if (IsPostBack)
            return;
        Demo_Area da = new Demo_Area();
        da.Pid = 0;
        BindCountry(da);

    }
   
    #region 递归绑定国家和地区
    private void BindCountry(Demo_Area parma)
    {
        DataSet ds = BindCity(parma);
        if (ds.Tables[0].Rows.Count <= 0)
            return;
        intFlag++;
        int i = 0;
        for (; i < ds.Tables[0].Rows.Count; i++)
        {
            Demo_Area area = new Demo_Area();
            area.Name = ds.Tables[0].Rows[i]["Name"].ToString();
            area.Id = Convert.ToInt32(ds.Tables[0].Rows[i]["Id"].ToString());
            BindDDL(area);
            area.Pid = Convert.ToInt32(ds.Tables[0].Rows[i]["Id"].ToString());
            BindCountry(area);
        }
        if (ds.Tables[0].Rows.Count <= i)
            intFlag--;
    }
    #endregion

    #region 绑定DropDrownList
    private void BindDDL(Demo_Area parma)
    {
        string temp = "";
        for (int i = 0; i < intFlag - 2; i++)
        {
            temp += " ┃";
        }
        if (intFlag != 1)
            temp += " ┣";
        temp += parma.Name;
        DropDownList1.Items.Add(new ListItem(temp, parma.Id.ToString()));

    }
    #endregion

    #region  查询数据并返回一张虚拟表
    private DataSet BindCity(Demo_Area param)
    {
        SqlConnection con = new SqlConnection(connstr);
        con.Open();
        string strSQL = "select * from Area_MS where Pid=" + param.Pid;
        SqlDataAdapter sda = new SqlDataAdapter(strSQL, con);
        DataSet ds = new DataSet();
        sda.Fill(ds);
        return ds;
    }

    #endregion

效果图:

转载于:https://www.cnblogs.com/_ymw/archive/2010/10/18/YMW.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值