Pergunta

Estou tendo problemas para obter todos os valores no Datalist

Aqui está o problema:

Eu tenho dados que é preenchido dinamicamente da tabela no banco de dados, a página ASPX é a página de pedidos em massa, para que haja muitos itens no Datalist e eu quero que o usuário seja capaz de selar vários pedidos de uma só vez em modo e selecione um Buuton em O que é chamado de check -out, a pergunta é como faço para fazer através de todas as caixas de seleção e caixas de texto e obter o valor. Qualquer idéia que uma codificação ajudaria a deverendentemente, pois eu ainda não codificava.

Aqui está minha página ASPX:

 <asp:DataList ID="DataList1" runat="server" BackColor="White" BorderColor="#CCCCCC" 
        BorderStyle="None" BorderWidth="1px" CellPadding="3" DataKeyField="Id" 
        DataSourceID="SqlDataSource1" GridLines="Both">
    <FooterStyle BackColor="White" ForeColor="#000066" />
    <ItemStyle ForeColor="#000066" />
    <SelectedItemStyle BackColor="#669999" Font-Bold="True" ForeColor="White" />
    <HeaderStyle BackColor="#006699" Font-Bold="True" ForeColor="White" />
    <FooterTemplate>
        <asp:Button ID="btnNext" runat="server" Text="CheckOut" 
            onclick="btnNext_Click" />
    </FooterTemplate>
    <ItemTemplate>
        <asp:Label ID="TitleLabel" runat="server" Text='<%# Eval("Title") %>' />
        <br />
        <asp:Image ID="Image1" ImageUrl='<%# Eval("PictureUrlMedium") %>' runat="server" />

        <br />
         <asp:Label ID="DescriptionLabel" runat="server" 
            Text='<%# Eval("Description") %>' />
        <br />
        <br />
        <asp:Table ID="Table1" runat="server">
        <asp:TableRow>
        <asp:TableCell><asp:CheckBox ID="chkSmall" runat="server" Enabled="true" Width="20px"/>

Pequena

Médio

Grande

Extra grande

2xlarge

3xlarge

4xlarge

5xlarge


    </ItemTemplate>
</asp:DataList>
<asp:SqlDataSource ID="SqlDataSource1" runat="server" 
  ConnectionString="<%$ ConnectionStrings:LocalSqlServer %>"  

    SelectCommand="SELECT [Id], [Title], [Description], [Price], [CategoryId], [PictureUrlSmall], [PictureUrlMedium], [PictureUrlLarge], [Deleted] FROM [Product]"></asp:SqlDataSource>
Foi útil?

Solução

Você pode conseguir isso percorrendo os itens de dados do seu evento de clique:

foreach(DataListItem item in YourDataList.Items){
    CheckBox chkSmall = (CheckBox)item.FindControl("chkSmall");
    chkSmall.Checked gives you the value
}

Outras dicas

Após o postback, percorra os itens do datalista e obtenha o status da caixa de seleção usando o FindControl. Você pode querer adicionar algo ao item do Datalist para identificar a entidade real correspondente à caixa de seleção.

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top