Sqlserver
 sql >> Base de données >  >> RDS >> Sqlserver

Comment obtenir la valeur de la case à cocher de gridview lorsque la case à cocher OnCheckedChanged

utilisez GridViewRow comme suit... Vous pouvez obtenir la ligne actuelle de la case à cocher qui est cochée en utilisant NamingContainer propriété comme suit...

Modifier :-Modifiez le balisage et ajoutez Hiddenfield pour conserver la valeur de Selected comme suit...

<asp:TemplateField HeaderText="ใช่">          
            <ItemTemplate>              
                <asp:CheckBox ID="chkSelected" runat="server"  Checked='<%# Eval("Selected").ToString().Equals("True") %>'
                     AutoPostBack="true" OnCheckedChanged="chkSelected_CheckedChanged" CssClass="chkBox" />     
                <asp:HiddenField ID="hiddenField1" Value='<%# Eval("Selected").ToString() %>' runat="server" />    
            </ItemTemplate>       
 </asp:TemplateField> 

Ensuite, vous pouvez obtenir le champ caché comme suit et sa valeur également

protected void chkSelected_CheckedChanged(object sender, EventArgs e)
    {
         GridViewRow row = (GridViewRow)(((CheckBox)sender).NamingContainer);
         HiddenField hdnCheck=(HiddenField)row.Cells[4].FindControl("hiddenField1");
         if (Convert.ToString(hdnCheck.Value != "")
           {
               Response.Write("true");
           }
           else
           {
               Response.Write("false");
           }

         // Edit: You can easily get Checkbox which has been checked, and do your logic
         CheckBox chkSelect=(CheckBox)sender;
         if (chkSelect.Checked)
           {
               Response.Write("true");
           }
           else
           {
               Response.Write("false");
           }    
    }