Кажется достаточно простым, но я не могу понять это. Я пробовал этот код:
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>
Спасибо за ваше время и силы.
Причина, по которой он не выбирает элементы, заключается в том, что событие Page_Load вызывается до привязки элементов CheckBoxList. Поэтому, чтобы выбрать все элементы при загрузке страницы, у вас есть два варианта:
Первый вариант: введите тот же код, который вы используете в событии OnDataBound в CheckBoxList.
Измените разметку CheckBoxList следующим образом:
<asp:CheckBoxList OnDataBound="CheckBoxListDivision_DataBound"
ID="CheckBoxListDivision" runat="server" DataSourceID="SqlDataSourceDivisions" DataTextField="Name" DataValueField="ID"
RepeatColumns="4" >
</asp:CheckBoxList>
И добавьте это в код:
protected void CheckBoxListDivision_DataBound(object sender, EventArgs e)
{
foreach (ListItem item in CheckBoxListDivision.Items)
{
item.Selected = true;
}
}
Второй вариант: Удалите SqlDataSource из вашей разметки и программно привяжите CheckBoxList в событии Page_Load, а затем привязав CheckBoxList, выполните цикл, и вы сможете выбрать элементы.
Надеюсь это поможет.