这是我第一次尝试从Repeater控件中动态填充RadioButtonList。到目前为止情况并不顺利。
我正在尝试这个我在这里找到的代码,据说这个代码适用于编写它的人:
protected void fillRepeater_onitembound(object sender, RepeaterItemEventArgs e)
{
if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
{
sql = "select PurchaseTypeID,PurchaseType from PurchaseType";
object obj = null;
ds = obj.openDataset(sql);
ListItem li;
RadioButtonList rbtl = (RadioButtonList)e.Item.FindControl("radioatt");
if (rbtl != null)
{
for (int i = 0; i < dt.Rows.Count; i++)
{
li = new ListItem();
li.Text = dt.Rows[i]["PurchaseType"].ToString();
li.Value = dt.Rows[i]["PurchaseTypeID"].ToString();
rbtl.Items.Add(li);
}
}
}
}
<asp:Repeater ID="Repeater2" runat="server" OnItemDataBound="fillRepeater_onitembound">
<ItemTemplate>
<table style="width:100%;border: 1px solid black;">
<tr>
<td style="width:50%;border-collapse: collapse;border: 1px solid black;">
Purchased:<asp:radiobuttonlist ID="rblPurchaseType" runat="server" RepeatDirection="Horizontal" TextAlign="Right" style="display:inline;"></asp:radiobuttonlist></td>
<td style="text-align:center;border: 1px solid black;">
</td>
</tr>
<tr>
</table>
...
...
...
</asp:Repeater>
然而,我遇到了错误:
&#39;对象&#39;不包含&#39; openDataset&#39;的定义没有扩展方法&#39; openDataset&#39;接受类型&#39;对象&#39;的第一个参数。可以找到(你错过了使用指令或汇编参考吗?
任何想法有什么不对?
更新
public DataTable LoadDataFromDatabase(string query)
{
DataTable dt = new DataTable();
using (SqlConnection connection = new SqlConnection(connStr))
using (SqlDataAdapter adapter = new SqlDataAdapter(query, connection))
{
try
{
adapter.Fill(dt);
}
catch (Exception ex)
{
//handle error if needed
}
}
return dt;
}
string myQuery = "SELECT PurchaseTypeID, PurchaseType FROM PurchaseType ORDER BY PurchaseType";
string rbtl = Repeater2.FindControl("rblPurchaseType");
rbtl.DataSource = LoadDataFromDatabase(myQuery);
rbtl.DataTextField = "PurchaseType";
rbtl.DataValueField = "PurchaseTypeID";
rbtl.DataBind();
答案 0 :(得分:0)
究竟是什么obj
?除非你把它归还给具有openDataset
属性的东西,否则它永远不会起作用。
我使用的是一种简单的方法,它从查询中返回DataTable
并将其绑定到RadioButtonList
public DataTable LoadDataFromDatabase(string query)
{
DataTable dt = new DataTable();
using (SqlConnection connection = new SqlConnection(YourConnectionString))
using (SqlDataAdapter adapter = new SqlDataAdapter(query, connection))
{
try
{
adapter.Fill(dt);
}
catch (Exception ex)
{
//handle error if needed
}
}
return dt;
}
现在,您可以使用此方法快速,简单地从数据库中获取所需内容,并将其绑定到您需要的任何控件。
string myQuery = "SELECT PurchaseTypeID, PurchaseType FROM PurchaseType ORDER BY PurchaseType";
rbtl.DataSource = LoadDataFromDatabase(myQuery);
rbtl.DataTextField = "PurchaseType";
rbtl.DataValueField = "PurchaseTypeID";
rbtl.DataBind();
PS rbtl
在你的情况下总是null
,因为aspx中的RadioButton的ID是rblPurchaseType
而你在radioatt
上使用FindControl,请确保这些是一样的。