ASP.NET巧妙利用repeater控件和checkBox控件实现批量操作

   一般的CMS(Content Manager System)中,不可避免的会涉及批量操作。比如显示一页数据,一个良好的设计都会加上批量删除、批量推荐等操作。

   在ASP.NET中,做这样的批量操作非常简单,以批量删除为例,我们仅需要checkBox控件用来多选,外加一个批量删除按钮。显示数据这里采用repeater控件。

   下面是我的工程中一段代码:

   aspx前台文件代码:

 

<table>



                   <tbody>



                       <tr>



                           <thclass="th_CheckBox"></th>



                           <thclass="th_Floor">楼层号</th>



                           <thclass="th_Room">房间号</th>



                           <thclass="th_ComputerNumber">电脑编号</th>



                           <thclass="th_ProName">问题名称</th>



                           <thclass="th_ProType">问题类型</th>



                           <thclass="th_ProDescription">问题描述</th>



                           <thclass="th_Operate">操作</th>



                       </tr>



                       <asp:RepeaterID="UnProRepeater" runat="server">



                           <ItemTemplate>



                               <tr>



                                  <td><asp:CheckBox ID="cdDelete" ToolTip='<%#Eval("id") %>' Text="" runat="server"/></td>



                                  <td><%# Eval("floor") %></td>



                                  <td><%# Eval("rmNumber")%></td>



                                  <td><a href='addUnFinishedPro.aspx?id=<%# Eval("id")%>'><%# Eval("cmNumber")%></a></td>



                                  <td><%# Eval("name") %></td>



                                  <td><%# Eval("typeName")%></td>



                                  <td><%# cutString(Eval("description").ToString(),15,"...")%></td>



                                  <td><asp:LinkButton ID="lbtnDelete"CommandArgument='<%# Eval("id") %>' OnClientClick="returnconfirm('真的要删除吗?')" OnClick="lbtnDelete_Click"runat="server">删除</asp:LinkButton></td>



                               </tr>



                          </ItemTemplate>



                      </asp:Repeater>     



                   </tbody>



  </table>



  

   大家不要被这么代码吓到了,真正有用的只有第一个<tr></tr>块里的<th class="th_CheckBox"></th>,目的是给单选框留出一列;第二个<tr></tr>块里的<td><asp:CheckBox ID="cdDelete" ToolTip='<%#Eval("id") %>' Text="" runat="server"/></td>,真正的显示checkBox控件。其中ToolTip属性是为了携带记录id,有了记录id我们才能操作这条记录。为啥用这个属性呢?因为只有这个属性最合适,让人比较意外的是ASP.NET的checkBox竟然没有value属性,找来找去,只有ToolTip这个属性能用来携带id了,而且用户把鼠标放到checkBox上还会显示出记录id,增加了程序的神秘感。把repeater控件绑定数据之后,每条数据前都会多出一个单选框,这样就达到目的了。作为例子,上边这段代码没必要写这么多,但是为了给读者一个完整的展示,还是把代码写全了。

   在界面上再添加一个批量删除按钮,前台就搞定了,怎么在批量删除按钮事件中删除选中的项呢?

   aspx.cs后台代码:

 

protected void btnDelete_Click(object sender, EventArgs e)



   {



      bool result = true;



      //遍历repeater控件的itemtemplate模版



      foreach (RepeaterItem item in UnProRepeater.Items)



      {



          CheckBox cb = (CheckBox)item.FindControl("cdDelete"); //根据控件id获得控件对象,cdDelete是checkBox控件的id



          if (cb.Checked == true)



          {



              //删除操作,根据id删除记录,cb.ToolTip里存放的就是记录id



          }



      }



      //别忘了删除之后要重新绑定数据的哦。。。。。



   }



  

   代码中已经加上详细的注释,相信您一看即懂。

   通过这个简单的小例子,展示了ASP.NET通过repeater控件和checkBox控件进行批量操作,希望对大家的学习有所帮助!

 

你可能感兴趣的:(checkbox)