Skip to main content

Nested GridView in ASP.NET Using c# with show/hide


In This example shows how to create Nested GridView In Asp.Net Using C# And VB.NET With Expand Collapse Functionality.

Sending Email from Asp.net With Dynamic Content , SQL Server- Case Sensitive Search in SQL Server


I have used JavaScript to Create Expandable Collapsible Effect by displaying Plus Minus image buttons.

Nested GridView Example In Asp.Net With Expand Collapse

Customers and Orders Table of Northwind Database are used to populate nested GridViews.

Drag and place SqlDataSource from toolbox on aspx page and configure and choose it as datasource from smart tags

Go to HTML source of page and add 2 TemplateField in <Columns>, one as first column and one as last column of gridview.

Place another grid in last templateField column.

Markup of page after adding both templatefields will like as shown below.



HTML SOURCE
     <asp:GridView ID="gvMaster" runat="server" 
                 AllowPaging="True" 
                   AutoGenerateColumns="False" 
                  DataKeyNames="CustomerID" 
                 DataSourceID="SqlDataSource1" 
                  onrowdatabound="gvMaster_RowDataBound">
    <Columns>
    <asp:TemplateField>
       <ItemTemplate>
       <a href="javascript:collapseExpand('customerID-
                 <%# Eval("CustomerID") %>');">
      <img id="imagecustomerID-<%# Eval("CustomerID") %>" 
             alt="Click to show/hide orders" 
            border="0" src="plus.png" /></a>
       </ItemTemplate>
   </asp:TemplateField>
   <asp:BoundField DataField="CustomerID" 
                   HeaderText="CustomerID"/>
   <asp:BoundField DataField="CompanyName" 
                    HeaderText="CompanyName"/>
     
    <asp:TemplateField>
    <ItemTemplate>
   <tr><td colspan="100%">
   <div id="customerID-<%# Eval("CustomerID") %>" 
        style="display:none;
         position:relative;left:25px;">
       
    <asp:GridView ID="nestedGridView" runat="server" 
                 AutoGenerateColumns="False" 
                  DataKeyNames="OrderID">
    <Columns>
   <asp:BoundField DataField="OrderID" HeaderText="OrderID"/>
    <asp:BoundField DataField="OrderDate" HeaderText="OrderDate"/>
   <asp:BoundField DataField="Freight" HeaderText="Freight"/>
    </Columns>
    </asp:GridView>
    </div>
    </td></tr>
    </ItemTemplate>
    </asp:TemplateField>
    </Columns>
   </asp:GridView>
    
  <asp:SqlDataSource ID="SqlDataSource1" runat="server" 
   ConnectionString="<%$ ConnectionStrings:ConnectionString %>" 
   SelectCommand="SELECT [CustomerID], [CompanyName] 
                FROM [Customers]">
   </asp:SqlDataSource>

Add following JavaScript in head section of page.
<script type="text/javascript">
function collapseExpand(obj)
{
  var gvObject = document.getElementById(obj);
  var imageID = document.getElementById('image' + obj);
 
 if (gvObject.style.display == "none")
      {
         gvObject.style.display = "inline";
         imageID.src = "minus.png";
      }
  else
     {
         gvObject.style.display = "none";
         imageID.src = "plus.png";
     }
}
</script>
Write following code in RowDataBound Event of parent Grid to populate nested gridview.

C#
protected void gvMaster_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
 string customerID = Convert.ToString(DataBinder.Eval(e.Row.DataItem, "CustomerID"));
            GridView gvChild = (GridView)e.Row.FindControl("nestedGridView");
            SqlDataSource gvChildSource = new SqlDataSource();
            gvChildSource.ConnectionString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
            gvChildSource.SelectCommand = "SELECT [OrderID], [OrderDate],[Freight] FROM [Orders] WHERE [CustomerID] = '" + customerID + "'";
            gvChild.DataSource = gvChildSource;
            gvChild.DataBind();     }
}

VB.NET
Protected Sub gvMaster_RowDataBound(sender As Object, e As GridViewRowEventArgs)
 If e.Row.RowType = DataControlRowType.DataRow Then
  Dim customerID As String = Convert.ToString(DataBinder.Eval(e.Row.DataItem, "CustomerID"))
  Dim gvChild As GridView = DirectCast(e.Row.FindControl("nestedGridView"), GridView)
  Dim gvChildSource As New SqlDataSource()
  gvChildSource.ConnectionString = ConfigurationManager.ConnectionStrings("ConnectionString").ConnectionString
  gvChildSource.SelectCommand = "SELECT [OrderID], [OrderDate],[Freight] FROM [Orders] WHERE [CustomerID] = '" + customerID + "'"
  gvChild.DataSource = gvChildSource
  gvChild.DataBind()
 End If
End Sub

I hope this will be helpful for you. I would like to have any feedback from you. 
Your valuable feedback, question, or comments about this article are always welcome.

Comments

Popular posts from this blog

How to send mail asynchronously in asp.net with MailMessage

With Microsoft.NET Framework 2.0 everything is asynchronous and we can send mail also asynchronously. This features is very useful when you send lots of bulk mails like offers , Discounts , Greetings . You don’t have to wait for response from mail server and you can do other task . By using     SmtpClient . SendAsync Method (MailMessage, Object)    you need to do  System.Net.Mail has also added asynchronous support for sending email. To send asynchronously, you need need to Wire up a SendCompleted event Create the SendCompleted event Call SmtpClient.SendAsync smtpClient.send() will initiate the sending on the main/ui  thread and would block.  smtpClient.SendAsync() will pick a thread from the .NET Thread Pool and execute the method on that thread. So your main UI will not hang or block . Let's create a simple example to send mail. For sending mail asynchronously you need to create a event handler that will notify that mail success...

How to hide url parameters in asp.net

There are different ways to Hide the URL in asp.net , you can choose any one from bellow options . Previously I was Explained about the  Difference between Convert.tostring and .tostring() method Example  ,   Reasons to use Twitter Bootstrap , How to Register AJAX toolkit in web.config file in asp.net a) Using Post Method b) Using Of Session . c) URL Encoding & decoding process . d) Using Server.Transfer() instead of Response.Redirect() method (1)Use a form and POST the information. This might require additional code in source pages, but should not require logic changes in the target pages (merely change Request.QueryString to Request.Form). While POST is not impossible to muck with, it's certainly less appealing than playing with QueryString parameters. (2)Use session variables to carry information from page to page. This is likely a more substantial effort compared to (1), because you will need to take session variable checking into account...

View online files using the Google Docs Viewer

Use Google Docs Viewer for Document viewing within Browser I was looking for a way to let users see Microsoft Word Doc or PDF files online while using my application without leaving their browser without downloading files and then opening it to view with Word or PDF viewer . I was looking for some way out either via any PHP or Microsoft.NET libraries, did some googling on that; but later on I just got an idea that google already has all code written for me.. when I have any email attachment in PDF or DOC or DOCX google does it for me ..! Even while searching I can see PDFs by converting them in HTML. So I just googled it up and found that Google already has this ability that we can use Google Docs Viewer without any Google Account Login . YES that's true no Google Account login is required. It's damn simple and easy. Just pass document path as attachment as parameter and we are done. Google Docs Viewer gives us ability to embed PDF, DOC/DOCX, PPT, TIFF:...