zoukankan      html  css  js  c++  java
  • findcontrol()方法和repeater中的checkbox

    今天要给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;
    }

    转自http://www.cnblogs.com/FrameWork/archive/2006/11/25/571928.html

  • 相关阅读:
    图论
    城市吸引力指数
    bzoj3529(莫比乌斯反演+离线+树状数组)
    强制关闭tomcat
    bzoj2154(莫比乌斯反演)
    等差数列求和模板
    联想的显示屏校准(困难)
    bzoj2301(莫比乌斯反演)
    莫比乌斯反演模版
    菜鸟物流的运输网络(网络流)
  • 原文地址:https://www.cnblogs.com/JuneZhang/p/1905409.html
Copyright © 2011-2022 走看看