?
Solved

How to add checkbox programatically in Gridview?

Posted on 2009-05-19
8
Medium Priority
?
697 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
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 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
Python: Series & Data Frames With Pandas

Learn the basics of Python’s pandas library of series & data frames and how we can use these tools for data manipulation.

 
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

Wouldn’t it be nice if you could test whether an element is contained in an array by using a Contains method just like the one available on List objects? Wouldn’t it be good if you could write code like this? (CODE) In .NET 3.5, this is possible…
If you need to start windows update installation remotely or as a scheduled task you will find this very helpful.
NetCrunch network monitor is a highly extensive platform for network monitoring and alert generation. In this video you'll see a live demo of NetCrunch with most notable features explained in a walk-through manner. You'll also get to know the philos…
Visualize your data even better in Access queries. Given a date and a value, this lesson shows how to compare that value with the previous value, calculate the difference, and display a circle if the value is the same, an up triangle if it increased…
Suggested Courses

762 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