Checkbox OnClick/ItemCommand in Repeater or DataList
I need to do some server side logic on a row in my repeater when a CheckBox is clicked inside the repeater control.
开发者_开发知识库Anyone know how to go about this?
The way I see it you cant fire item command and if you use the CheckBoxes OnClick you cant get the repeater row.
Here is a quick mock-up of how I have done similar in the past.
<asp:Repeater id="repeater1" runat="server" OnItemDataBound="repeater1_OnItemDataBound" >
<ItemTemplate>
<asp:CheckBox ID="chk" runat="server" OnCheckedChanged="Check_Changed" AutoPostBack="true" />
</ItemTemplate>
</asp:Repeater>
codebehind:
public class Model {
public int Id { get; set; }
public string Name { get; set; }
}
public partial class Checkboxes : System.Web.UI.Page {
protected void Page_Load(object sender, EventArgs e) {
if(!IsPostBack ) {
repeater1.DataSource = new List<Model> {
new Model { Id = 1, Name = "a" },
new Model { Id = 2, Name = "b" },
new Model { Id = 3, Name = "c" } };
repeater1.DataBind();
}
}
protected void repeater1_OnItemDataBound(Object sender, RepeaterItemEventArgs e) {
if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem) {
var item = e.Item.DataItem as Model;
if (item != null) {
var chk = e.Item.FindControl("chk") as CheckBox;
if (chk != null) {
chk.Text = item.Name;
chk.InputAttributes.Add("value", item.Id.ToString());
}
}
}
}
protected void Check_Changed(Object sender, EventArgs e) {
var id = ((CheckBox) sender).InputAttributes["value"];
//you now have access to the item id and can manipulate at will.
}
}
Try this codebehind:
protected void Checked_Changed(object sender, EventArgs e)
{
var item = ((CheckBox)sender).Parent as RepeaterItem;
// now you have the repeater row. You can travers further up the controls if you use Parent.Parent...
}
You could use the OnClick event to loop through each item in the repeater, and check the value of each checkbox, (IsChecked == true).
Just make sure that you are not calling a "DataBind()" on the repeater, otherwise that might cause issues.
精彩评论