Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium

x
?
Solved

How to add checkbox programatically in Gridview?

Posted on 2009-05-19
8
Medium Priority
?
711 Views
Last Modified: 2013-12-17
Hi,
I'm able to add button programmatically, BUT not checkbox. Any ideas?
gvwInbox.AllowSorting = True
                gvwInbox.AllowPaging = True
                gvwInbox.PageSize = 10
 
                Dim btnView1 As ButtonField = New ButtonField()
                btnView1.ButtonType = ButtonType.Button
                btnView1.Text = "View"
                btnView1.CommandName = "View"
 
                Dim chk As CheckBoxField = New CheckBoxField
                chk.DataField = "subject"
 
                'Add in web controls
                gvwInbox.Columns.Add(btnView1)
                gvwInbox.Columns.Add(chk)
 
                gvwInbox.DataSource = objInbox.GetInbox(User.Identity.Name.ToString)
                gvwInbox.DataBind()

Open in new window

0
Comment
Question by:tangteng78
  • 4
  • 2
  • 2
8 Comments
 
LVL 4

Expert Comment

by:RamanaChoudary
ID: 24424845
0
 
LVL 11

Expert Comment

by:Muhammad Ousama Ghazali
ID: 24424892
Make sure the database field set using DataField property of the CheckBoxField is a boolean field rather than a textual one, e.g. Bit (SQL Server) or Yes/No (Access). I just tested it here and it works with boolean fields only.
0
 
LVL 4

Expert Comment

by:RamanaChoudary
ID: 24424900
0
NEW Veeam Backup for Microsoft Office 365 1.5

With Office 365, it’s your data and your responsibility to protect it. NEW Veeam Backup for Microsoft Office 365 eliminates the risk of losing access to your Office 365 data.

 
LVL 11

Expert Comment

by:Muhammad Ousama Ghazali
ID: 24424910
You need to replace "Subject" with some other field like "IsCurrent" or whatever but a boolean field.
0
 

Author Comment

by:tangteng78
ID: 24428750
The links doesn't provide the insight on how to add checkbox programatically.
However, i put in the checkbox in the itemtemplate. See below.

how do i access the "subject" value if i selected on certain checkbox on a click of a button (the button defined separate outside of the gridview)?

    Protected Sub btnDelete_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles btnDelete.Click

        For Each row As GridViewRow In gvwInbox.Rows

            Dim cb As CheckBox = row.FindControl("chk")
           
            'I'm stuck here...do not know how to get the 'subject' value on specific checkbox checked.

        Next

    End Sub

<asp:GridView ID="gvwInbox" runat="server" AutoGenerateColumns="false" AllowSorting="true" >
                <Columns>
                    <asp:TemplateField>
                        <HeaderTemplate>
                            <%#Eval("subject")%>
                        </HeaderTemplate>
                        <ItemTemplate>
                        <table>
                            <tr>
                                <td>
                                    <asp:CheckBox ID="chk" runat="server" /></td>
                                <td><%#Eval("subject")%></td>
                            </tr>
                            <tr>
                                <td>
                                    <%#Eval("body")%>
                                </td>
                            </tr>
                        </table>
                        </ItemTemplate>
                    </asp:TemplateField>
                </Columns>
            </asp:GridView>

Open in new window

0
 
LVL 11

Expert Comment

by:Muhammad Ousama Ghazali
ID: 24428775
Please use the snippet below to get the checkbox, and then use its Checked property to evaluate if it is checked or not. Make sure if you use multiple ItemTemplates, pass the correct index position value into the Cells() collection.

Dim chkTemp As CheckBox = CType(row.Cells(0).FindControl("chk"), CheckBox)

Open in new window

0
 

Author Comment

by:tangteng78
ID: 24428827
can you elaborate on this?

"Make sure if you use multiple ItemTemplates, pass the correct index position value into the Cells() collection."
0
 
LVL 11

Accepted Solution

by:
Muhammad Ousama Ghazali earned 2000 total points
ID: 24428980
Right now you have declared only one TemplateField and most probably it will be the first if you are generating other columns automatically, hence making its index position within Columns or Cells collection 0. That is why my code has Cells(0) but in case you need to have more fields whether TemplateFields or BoundFields, make sure to pass the correct index postiion based upon the number of columns. Maybe the fact that I used the word ItemTemplates rather than TemplateFields has given wrong understanding above.
0

Featured Post

Visualize your virtual and backup environments

Create well-organized and polished visualizations of your virtual and backup environments when planning VMware vSphere, Microsoft Hyper-V or Veeam deployments. It helps you to gain better visibility and valuable business insights.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

International Data Corporation (IDC) prognosticates that before the current the year gets over disbursing on IT framework products to be sent in cloud environs will be $37.1B.
Real-time is more about the business, not the technology. In day-to-day life, to make real-time decisions like buying or investing, business needs the latest information(e.g. Gold Rate/Stock Rate). Unlike traditional days, you need not wait for a fe…
This Micro Tutorial will teach you how to add a cinematic look to any film or video out there. There are very few simple steps that you will follow to do so. This will be demonstrated using Adobe Premiere Pro CS6.
How can you see what you are working on when you want to see it while you to save a copy? Add a "Save As" icon to the Quick Access Toolbar, or QAT. That way, when you save a copy of a query, form, report, or other object you are modifying, you…
Suggested Courses
Course of the Month15 days, 5 hours left to enroll

578 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question