asp.net在Repeater嵌套的Repeater中使用复选框详解
更新时间:2018年12月01日 20:20:13 作者:森大科技
这篇文章主要介绍了asp.net在Repeater嵌套的Repeater中使用复选框,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
.aspx文件中:
<%--顶层Repeater--%>
<asp:Repeater ID="rptChannel" runat="server">
<itemtemplate>
<br /><b><%# Eval("ChannelName")%></b>
<%--嵌套的Repeater,指定使用后台创建的Releation来获取数据源--%>
<asp:Repeater ID="rptClassify" DataSource='<%# Eval("myrelation") %>' runat="server">
<itemtemplate>
<input type="checkbox" id="chk_FlagID" value='<%# Eval("FlagID")%>' runat="server" />
<asp:Label ID="lbl_FlagName" runat="server" Text='<%# Eval("FlagName")%>'></asp:Label>
</itemtemplate>
</asp:Repeater >
<%--end 嵌套的Repeater,指定使用后台创建的Releation来获取数据源--%>
</itemtemplate>
</asp:Repeater >
<%--end 顶层Repeater--%>
.aspx.cs文件中:
#region Repeater嵌套的Repeater中使用复选框
//★Repeater嵌套-经典运用★
string sqlstr1, sqlstr2;
sqlstr1 = "select distinct a.ChannelID,b.ChannelName from IE_FlagGroup a left join IE_Channel b on a.ChannelID=b.ChannelID where a.isClose=0 order by a.ChannelID asc";
sqlstr2 = "select * from IE_FlagGroup where isClose=0 order by FlagID asc";
DataSet dsChannel = DBFun.dataSetTwo(sqlstr1, "Channel", sqlstr2, "Classify", "myrelation");
dsChannel.Relations.Add("myrelation", dsChannel.Tables["Channel"].Columns["ChannelID"], dsChannel.Tables["Classify"].Columns["ChannelID"], false);
this.rptChannel.DataSource = dsChannel.Tables["Channel"];//绑定顶层Repeater(注意:只要绑定顶层就好,嵌套层不能绑定)
this.rptChannel.DataBind();
#endregion
//……略相关数据库操作代码
#region 设置Repeater嵌套的Repeater中相应的复选框为选中状态
string[] selTeamflag = drw["Teamflag"].ToString().Split(',');
HtmlInputCheckBox checkBox;
Repeater rpClass;
for (int i = 0; i < this.rptChannel.Items.Count; i++)
{
rpClass = (Repeater)this.rptChannel.Items[i].FindControl("rptClassify");
for (int j = 0; j < rpClass.Items.Count; j++)
{
checkBox = (HtmlInputCheckBox)rpClass.Items[j].FindControl("chk_FlagID");
if (selTeamflag.Contains(checkBox.Value))
checkBox.Checked = true;
}
}
#endregion
#region 获取Repeater嵌套的Repeater中的复选框所选择的值的组合,以","隔开
string str_Teamflag = "";
HtmlInputCheckBox checkBox;
Repeater rpClass;
for (int i = 0; i < this.rptChannel.Items.Count; i++)
{
rpClass = (Repeater)this.rptChannel.Items[i].FindControl("rptClassify");
for (int j = 0; j < rpClass.Items.Count; j++)
{
checkBox = (HtmlInputCheckBox)rpClass.Items[j].FindControl("chk_FlagID");
if (checkBox.Checked)
str_Teamflag += checkBox.Value + ",";
}
}
if (str_Teamflag != "")
{
//去除最后一个字符
//str_Teamflag = str_Teamflag.Substring(0, str_Teamflag.Length - 1);
str_Teamflag = str_Teamflag.Remove(str_Teamflag.Length - 1);
}
#endregion
以上所述是小编给大家介绍的asp.net在Repeater嵌套的Repeater中使用复选框,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
相关文章
asp.net中如何批量导出access某表内容到word文档
最近有项目需求是这样的,需要将某表中的每一条记录中的某些内容导出在一个word文档中。下面小编就把我的解决办法分享给大家,供大家参考2015-10-10
根据Eval()函数绑定的值,来显示GridView中的控件的方法
根据Eval()函数绑定的值,来显示GridView中的控件的方法,需要的朋友可以参考一下2013-03-03
asp.net AutoCompleteExtender的一个简单例子代码
asp.net AutoCompleteExtender的一个简单例子代码2009-12-12


最新评论