天天看點

ASP.NET控件Repeater周遊

該例子實作在Repeater通過勾選CheckBox後,通過底部按鈕擷取到所選的所有資料(之後可以進行批量删除、更新等操作)

首先,定義一個類

public class UserInfo
{
    public int ID { get; set; }

    public string name { get; set; }
}
           

在頁面上編寫Repeater模闆

<asp:Repeater ID="Repeater1" runat="server">
    <HeaderTemplate>
        <table style="width: 100%;">
            <tr>
                <td>
                    ID
                </td>
                <td>
                    名稱
                </td>
                <td>
                    操作
                </td>
            </tr>
    </HeaderTemplate>
    <ItemTemplate>
        <tr>
            <td>
                <%#Eval("ID")%>
            </td>
            <td>
                <%#Eval("name")%>
            </td>
            <td>
                <asp:CheckBox ID="CheckBox1" runat="server" dataID='<%#Eval("ID")%>' />操作
            </td>
        </tr>
    </ItemTemplate>
    <FooterTemplate>
        </table>
    </FooterTemplate>
</asp:Repeater>
           

資料初始化

protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                List<UserInfo> userList = new List<UserInfo>();
                for (int i = 0; i < 10; i++)
                {
                    UserInfo user = new UserInfo();
                    user.ID = i;
                    user.name = "BDS";
                    userList.Add(user);
                }
                Repeater1.DataSource = userList;
                Repeater1.DataBind();
            }
        }
           

頁面添加一個周遊操作的按鈕

asp:Button ID="Button1" runat="server" Text="周遊Repeater" οnclick="Button1_Click" />
           

周遊操作代碼

protected void Button1_Click(object sender, EventArgs e)
{
    List<int> idList = new List<int>();
    foreach (RepeaterItem item in Repeater1.Items)
    {
        CheckBox cb = item.FindControl("CheckBox1") as CheckBox;
        if (cb.Checked)
        {
            int id = int.Parse(cb.Attributes["dataID"]);
            idList.Add(id);
        }

    }

    foreach (var item in idList)
    {
        Response.Write(item + ",");
    }
}
           

繼續閱讀