今天要给repeater做上一个checkbox,然后能做到圈选反选,本来很简单的事,但是我发现了findcontrol方法的一个好的优点。
前台绑定方法如下:
<asp:Repeater ID="Repeater1" runat="server">
<ItemTemplate><asp:CheckBox ID="ch" runat="server" /></ItemTemplate>
</asp:Repeater>
后台代码如下:
foreach (Control c in this.Repeater1.Controls)
{
CheckBox check = (CheckBox)c.FindControl("ch");
if (check != null)
{
check.Checked = true;
}
}
好像细看没什么神奇,但是,从html代码中,你看到repeater生成的html代码如下:
<INPUT id=Repeater1_ctl00_ch type=checkbox name=Repeater1$ctl00$ch>
<INPUT id=Repeater1_ctl03_ch type=checkbox name=Repeater1$ctl03$ch>
地球人都知道服务器端的id到了客户端就极有可能在asp.net生成控件树的时候被asp.net自动重命名,为的防止一个页面多个重复id,那为什么在回发的时候后台又能够通过findcontrol("ch")来获取到呢?这就是asp.net为我们作的工作了。
顺便说说3种获得repeater中的checkbox 的方法:
foreach( RepeaterItem item in this.Repeater1.Items )
{
HtmlInputCheckBox check = (HtmlInputCheckBox)item.FindControl("cbDelete1");
if( check != null )
{
check.Checked = true;
}
}
for (int i=0;i<this.Repeater1.Items.Count;i++)
{
HtmlInputCheckBox check = (HtmlInputCheckBox)this.Repeater1.Items[i].FindControl("cbDelete1");
if( check != null )
{
check.Checked = true;
}
}
foreach (Control c in this.Repeater1.Controls)
{
HtmlInputCheckBox check = (HtmlInputCheckBox)c.FindControl("cbDelete1");
if( check != null )
{
check.Checked = true;
}
}
也可以
foreach (Control c in this.Repeater1.Controls)
{
CheckBox check = (CheckBox)c.FindControl("cbDelete1");
check.Checked = !check.Checked;
}