如何在页面首次加载时选中复选框列表中的所有复选框

本文关键字:复选框 列表 加载 | 更新日期: 2023-09-27 18:04:02

似乎很简单,但是我想不明白。我试过这个代码:

    protected void Page_Load(object sender, EventArgs e)
{
    if (!Page.IsPostBack)
    {
        foreach (ListItem item in CheckBoxListDivision.Items)
            item.Selected = true;
    }
}

和这个标记:

           <asp:CheckBoxList ID="CheckBoxListDivision" runat="server" DataSourceID="SqlDataSourceDivisions" DataTextField="Divisions" DataValueField="Divisions" RepeatColumns="4">
        </asp:CheckBoxList>
        <asp:SqlDataSource ID="SqlDataSourceDivisions" runat="server" ConnectionString="<%$ ConnectionStrings:WebPortal_Call4HealthReports_ConnectionString %>" SelectCommand="usp_HR_DivisionsSelectAll" SelectCommandType="StoredProcedure"></asp:SqlDataSource>

感谢您的时间和努力

如何在页面首次加载时选中复选框列表中的所有复选框

没有选择项目的原因是在绑定CheckBoxList项目之前调用了Page_Load事件。因此,为了在页面加载时选择所有项目,您有两个选项:

第一个选项:将您正在使用的代码放在CheckBoxList的OnDataBound事件中。

将CheckBoxList标记修改为:

   <asp:CheckBoxList OnDataBound="CheckBoxListDivision_DataBound"
 ID="CheckBoxListDivision"  runat="server" DataSourceID="SqlDataSourceDivisions" DataTextField="Name" DataValueField="ID" 
            RepeatColumns="4" >
    </asp:CheckBoxList>

并将其添加到code-behind:

protected void CheckBoxListDivision_DataBound(object sender, EventArgs e)
   {
       foreach (ListItem item in CheckBoxListDivision.Items)
       {
           item.Selected = true;
       }
   }

第二个选项:从标记中删除SqlDataSource并在Page_Load事件中以编程方式绑定CheckBoxList,然后在绑定CheckBoxList之后,执行循环,您将能够选择项目。