写在前面的话:在做一个项目的时候,需要使用到Repeater控件,并且在Repeater控件内放置了CheckBox控件来标志需要删除的行,选中后,在后台取到的CheckBox的值总是为false。最后发现是在PageLoad函数中没有判断是否是回发就绑定了Repeater控件的数据,那么每次进入页面CheckBox控件的值当然被刷新为false了。

前台页面:

 <div class="contianer p10">
<h3>
当前位置:<a href="Index.aspx" target="_self" >首页</a>>文章管理</h3>
<hr/>
<div class="content">
<asp:repeater ID="rptArticle" runat="server" ClientIDMode="Static" >
<HeaderTemplate>
<table border="0" cellspacing="0" cellpadding="0" width="100%">
<tr>
<th width="6%">选择</th>
<th width="6%">编号</th>
<th align="left">文章标题</th>
<th width="16%">发布时间</th>
<th width="10%">操作</th>
</tr>
</HeaderTemplate>
<ItemTemplate>
<tr>
<td><asp:CheckBox ID="cb_id" CssClass="checkall" runat="server" /></td>
<td><asp:Label ID="lb_id" runat="server" Text='<%#Eval("aNo")%>'></asp:Label></td>
<td><a href="ArticleShow.aspx?id=<%#Eval("aNo") %>"><%#Eval("aTitle")%></a></td>
<td><%#string.Format("{0:g}", Eval("aDate"))%></td>
<td><span><a href="ArticleShow.aspx?id=<%#Eval("aNo") %>">修改</a></span></td>
</tr>
</ItemTemplate>
<FooterTemplate>
</table>
</FooterTemplate>
</asp:repeater>
</div>
<div class="clear"></div>
<!-- 分页控件 -->
<div>
<webdiyer:AspNetPager ID="AspNetPager1" runat="server" HorizontalAlign="Right" ShowCustomInfoSection="Right"
Width="100%" Style="font-size: 12px" inputboxstyle="width:19px" CustomInfoHTML=""
ShowPageIndexBox="Always" AlwaysShow="false" FirstPageText="首页" LastPageText="尾页"
NextPageText="下一页" PrevPageText="上一页" CustomInfoStyle="FONT-SIZE: 12px" CurrentPageButtonClass="pagination"
PageSize="16" ForeColor="#1460AD" OnPageChanged="AspNetPager1_PageChanged">
</webdiyer:AspNetPager>
</div>
<!-- 分页控件end --> <br />
<asp:Button ID="BtnDelete" runat="server"
OnClientClick="return confirm( '确定要删除这些记录吗? ');"
onclick="BtnDelete_Click" Text="删除" />
&nbsp;
<asp:Label ID="lbMsg" runat="server" Text=""></asp:Label>
&nbsp;
<asp:Button ID="BtnAdd" runat="server" Text="添加"
onclick="BtnAdd_Click"/> </div>

后台页面:

 ArticleBLL bll = new ArticleBLL();
protected void Page_Load(object sender, EventArgs e)
{
this.lbMsg.Text = "";
if (!IsPostBack)
{
BindRepeater();
}
}
// 绑定数据
private void BindRepeater()
{
string strSql = "select * from article"; PagedDataSource ps = new PagedDataSource();
ps.DataSource = bll.GetDataList(strSql).DefaultView;
AspNetPager1.RecordCount = ps.Count;
ps.CurrentPageIndex = AspNetPager1.CurrentPageIndex - ;
ps.AllowPaging = true;
ps.PageSize = AspNetPager1.PageSize;
this.rptArticle.DataSource = ps;
this.rptArticle.DataBind();
}
// 分页控件事件绑定
public void AspNetPager1_PageChanged(object sender, EventArgs e)
{
BindRepeater();
}
// 添加文章
protected void BtnAdd_Click(object sender, EventArgs e)
{
Response.Redirect("ArticleShow.aspx");
}
// 删除
protected void BtnDelete_Click(object sender, EventArgs e)
{
for (int i = ; i < rptArticle.Items.Count; i++)
{
int id = Convert.ToInt32(((Label)rptArticle.Items[i].FindControl("lb_id")).Text);
CheckBox cb = (CheckBox)rptArticle.Items[i].FindControl("cb_id");
if (cb.Checked)
{
bll.Delete(id.ToString());
}
}
this.lbMsg.Text = "删除成功";
}

处理办法是在PageLoad里面判断是否是回发就可以了。

获取不到Repeater控件中的CheckBox选中状态的更多相关文章

  1. asp.net关于Repeater控件中的全选,批量操作

    今天在Repeater控件中碰到一个全选的操作,于是上网查了一下,找到一个觉得比较好,便记录下来, 界面代码简化之后(全选操作): <script type="text/javascr ...

  2. 在Repeater控件中使用if语句

    原文:在Repeater控件中使用if语句 .Afr_ARTICLE_TITLE { font: NORMAL BOLD 14px "Tahoma"; } .Afr_CONTENT ...

  3. 获取Repeater控件中的每一项数据

    var items = rptList.Items;//获取Repeater控件的所有项 foreach (RepeaterItem item in items)//遍历每一项内容 {   var t ...

  4. ASP.NET- 查找Repeater控件中嵌套的控件

    如何在Repeater的HeaderTemplate和FooterTemplate模板中寻找控件?在Repeater的ItemTemplate模板中的控件,我们可以用Items属性来遍历行并用Find ...

  5. asp.net 在repeater控件中加按钮

    在repeater中加入方法有两种方法: 第一种:是对repeater控件的行添加OnItemCommand事件,添加方法也是有两种 1.在设计页面中,选中repeater控件右击==>属性== ...

  6. JQuery获取指定元素中的checkbox选中状态的一些属性

    项目中用户上传病例数据,每一次上传自动生成一个病例文件夹,数据保存到后台,前端显示文件夹,现在的需求是勾选想要删除的文件夹的chenckbox,点击删除后,数据库和前端都相应的更新. 如果是静态页面, ...

  7. Repeater控件中的三目运算

    <asp:Repeater ID="rptimg" runat="server">        <ItemTemplate>      ...

  8. 获取WPF的DataGrid控件中,是否存在没有通过错误验证的Cell

     /// <summary>         /// 获取DataGrid的所有行是否存在验证错误.         /// </summary>         /// &l ...

  9. Repeater控件中的LinkButton(转)

    LinkButton小用法: 1.在使用时可以通过CommandName和CommandArgument属性联合起来绑定并传值,如:CommandName="record"Comm ...

随机推荐

  1. jstl foreach 取index

    <c:forEach var="myAccountInfo" items="${myAccountInfos}" varStatus="inde ...

  2. sqlserver ssms ctrl+e快捷键问题

    大部分的环境 win2008R2+sqlserver2014R2  ssms 中 ctrl+e都是可以执行查询的,某些情况下,ctrl+e是个组合键 ctrl+e已按下,正在等待按下第二个键 调整方法 ...

  3. 【Oracle】(savepoint)保存点的使用

    作用 保存点可以回退到事务的一部分,我们在操作数据库的过程中可以对事务分隔为几个部分,在操作失误的时候就可以回滚到某个点即可. 实现步骤 我们现在新建一张表TMP003 )); 第一步:插入第一条记录 ...

  4. J2EE项目集成SAP的BO报表

    网上的方案: 每个用户在自己的J2EE系统的用户登陆的同时登陆bo系统,这做法的缺点是登陆bo速度慢,而且如果J2EE用户比较多的话会在bo服务器生成很多的token. 最佳方案(自己研究): 1.调 ...

  5. word技巧-文本转化表格

    工作中不断学习,总能得到一点点成就感! 样例:

  6. iOS微信支付集成

    概述 iOS微信支付集成 详细 代码下载:http://www.demodashi.com/demo/10735.html 支付宝和微信都是业界的老大哥,相信大家都有所觉得文档.SDK都是各种坑吧(纯 ...

  7. [SpriteKit] 系统框架中Cocos2d-x制作小游戏ZombieConga

    概述 使用SpriteKit实现一个简单的游戏, 通过一个游戏来进行SpriteKit的入门, 熟练2D游戏的API, 也可以更好的结合在iOS应用中. 详细 代码下载:http://www.demo ...

  8. ant入门程序

    一. ant简单介绍 Ant是apache的一个核心项目, 它的作用是项目自己主动化构建, 由于它内置了Javac.Java.创建文件夹.拷贝文件等功能, 直接执行build.xml文件就能够编译我们 ...

  9. Oracle创建库

    oracle创建表空间 SYS用户在CMD下以DBA身份登陆: 在CMD中打sqlplus /nolog 然后再 conn / as sysdba --如果路径不存在则要创建路径 --创建临时表空间 ...

  10. HDUOJ--------1003 Max Sum

    Max Sum Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Sub ...