ListItem和DropDownList绑定数据

博客讲述了控件ListItem和DropDownList绑定数据库数据后,selectedindex数值始终为-1,无法选定索引号的问题。并给出解决办法,一是使用!IsPostBack,二是不直接绑定,将数据库数据连接到ArrayList后用控件的Items.Add方法添加内容,还给出了代码示例。
 遇到问题,控件ListItem和DropDownList绑定数据库数据后selectedindex数
值始终为-1,导致无法选定索引号。
>  考虑解决办法:
一,使用!IsPostBack
二,不直接绑定,数据库数据连接到ArrayList后再用控件的
> Items.Add方法添加内容
Dim myConn As SqlConnection = New SqlConnection("Server=localhost;" & _
                                                            "Database=Pubs;UID=sa;PWD=")
            Dim myCmd As SqlCommand = New SqlCommand("SELECT au_id," & _
                                                     "au_lname FROM Authors", myConn)


            myConn.Open()
            Dim myReader As SqlDataReader = myCmd.ExecuteReader()

            'Set up the data binding.
            AuthorList.DataSource = myReader
            AuthorList.DataTextField = "au_lname"
            AuthorList.DataValueField = "au_id"
            AuthorList.DataBind()

            'Close the connection.
            myConn.Close()
            myReader.Close()

            'Add the item at the first position.
            AuthorList.Items.Insert(0, "<-- Select -->")
在 ASP.NET 中,将 `DropDownList` 控件绑定到 `DataSet` 数据源是一个常见的数据绑定操作,通常用于从数据库或其他数据源动态加载选项。以下是实现该功能的详细步骤代码示例: ### 数据绑定步骤 1. **准备数据源**:使用 `SqlDataAdapter` 填充 `DataSet`,从数据库中获取数据。 2. **设置数据绑定属性**:指定 `DropDownList` 控件的 `DataTextField` `DataValueField`,分别用于显示文本值。 3. **执行数据绑定**:将 `DataSet` 中的表绑定到 `DropDownList` 控件,并调用 `DataBind()` 方法完成绑定。 ### 示例代码 ```csharp // 创建 SqlDataAdapter 并使用 SQL 查询填充 DataSet SqlDataAdapter da = new SqlDataAdapter("SELECT id, name FROM hy", conn); DataSet ds = new DataSet(); da.Fill(ds); // 关闭数据库连接 conn.Close(); // 设置 DropDownList数据绑定字段 DropDownList1.DataSource = ds.Tables[0]; DropDownList1.DataTextField = "name"; // 指定显示的文本字段 DropDownList1.DataValueField = "id"; // 指定值字段 // 执行数据绑定 DropDownList1.DataBind(); ``` ### 注意事项 - **字段匹配**:确保 `DataTextField` `DataValueField` 的值与 `DataSet` 中的列名完全匹配,否则会导致绑定失败或显示异常(如显示 `System.Data.DataRowView`)[^2]。 - **数据源类型**:`DataSet` 可以包含多个表,绑定时应选择正确的表(如 `ds.Tables[0]`)。 - **数据绑定时机**:通常在页面加载时(如 `Page_Load` 事件中)执行绑定操作,确保数据及时更新。 ### 插入默认项 在某些场景下,可能需要在下拉列表顶部插入一个默认提示项,例如“请选择父节点”,可以通过以下代码实现: ```csharp // 插入默认项 DropDownList1.Items.Insert(0, new ListItem("----请选择父节点----", "")); ``` ### 数据绑定异常处理 如果绑定后控件显示 `System.Data.DataRowView`,说明未正确设置 `DataTextField` `DataValueField`。请确保在调用 `DataBind()` 方法之前设置这些属性,以确保控件能够正确解析并显示数据。 ---
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值