На главной странице у меня есть стандартная DataGrid:
<asp:DataGrid ID="dgMyGrid" runat="server" AutoGenerateColumns="false">
<Columns>
<asp:TemplateColumn>
<HeaderTemplate>
<asp:CheckBox CssClass="Checker" ID="cbSelectAll" runat="server" />
</HeaderTemplate>
<ItemTemplate>
<asp:CheckBox ID="cbSelect" runat="server" />
</ItemTemplate>
</asp:TemplateColumn>
</Columns>
</asp:DataGrid>
Имейте следующий jQuery, который делает флажок заголовка выбрать все:
$(document).ready(function() {
$("#ctl00_ContentPlaceHolder1_dgMyGrid_ctl01_cbSelectAll").click(function() {
$("#<%=dgID %> :checkbox").each(function(i)
{
this.checked = $("#ctl00_ContentPlaceHolder1_dgMyGrid_ctl01_cbSelectAll").is(":checked")
});
});
});
это работает, но немного уродливо - я не могу получить идентификатор клиента для флажка заголовка с
<% = cbSelectAll.ClientID%> (как я сделал для сетки данных) Возможно, потому что javascript отображается перед этим элементом управления. Есть ли для меня более элегантный способ получить clientID моего флажка из сетки данных? Я думаю, что было бы лучше, если бы я не указывал код клиента таким образом.
Извиняюсь, если ответ на этот вопрос очевиден, это мой первый день, когда я пробую jQuery! :)