Connecting Tech Pros Worldwide Help | Site Map

Multi column header gridview | ASP.Net 2.0

  #1  
Old August 19th, 2007, 08:25 PM
tirath
Guest
 
Posts: n/a
hi,
I want to display data in on my web page, in gridview in this format:
Group A Group B
A1 A2 B1 B2
Test 1 1 2 1 2
Test 2 1 2 1 2

Group A is header to columns A1 and A2 and Group B is header to
columns B1 and B2.
How do i add header to columns A1 A2 and B1 B2?

I am using ASP.Net 2.0. Please help me. Is it possible with some other
control instead of gridview?

Thanks

  #2  
Old August 20th, 2007, 08:15 AM
=?Utf-8?B?TGFkaXNsYXYgTXJua2E=?=
Guest
 
Posts: n/a

re: Multi column header gridview | ASP.Net 2.0


Hi,
try to use code like following (its handler for RowDataBound event where you
can modify attributes for any row or cell):

protected void GridView1_RowDataBound(object sender,
GridViewRowEventArgs e)
{
if (e.Row.RowType == DataControlRowType.Header)
{
// imagine you have 5 cells and you want only three header cells
// 2nd and 3rd columns will have one header
e.Row.Cells[1].Attributes.Add("colspan", "2");
// 4th and 5th columns will also have one header
e.Row.Cells[3].Attributes.Add("colspan", "2");
e.Row.Cells.RemoveAt(2); // you have reduced count of cells by one
e.Row.Cells.RemoveAt(3); // so now you have only 4 cells = last
has index 3
}
}

I hope code with comments is self explanatory. Don't use sorting when you
want to span some columns. Sort expression will still use only column where
header was supposed to be use.

Regards,
Ladislav

"tirath" wrote:
Quote:
hi,
I want to display data in on my web page, in gridview in this format:
Group A Group B
A1 A2 B1 B2
Test 1 1 2 1 2
Test 2 1 2 1 2
>
Group A is header to columns A1 and A2 and Group B is header to
columns B1 and B2.
How do i add header to columns A1 A2 and B1 B2?
>
I am using ASP.Net 2.0. Please help me. Is it possible with some other
control instead of gridview?
>
Thanks
>
>
  #3  
Old August 20th, 2007, 09:27 AM
=?Utf-8?B?U2VyZ2V5IFBvYmVyZXpvdnNraXk=?=
Guest
 
Posts: n/a

re: Multi column header gridview | ASP.Net 2.0


After looking at the following article:
http://dotnetslackers.com/GridView/r...ta_Exists.aspx

I have come up with an idea that may solve your particular problem: If you
override a GridView and then override its CreateChildControls methods similar
to the following:

protected override int CreateChildControls(System.Collections.IEnumerable
dataSource, bool dataBinding)
{
int result = base.CreateChildControls(dataSource, dataBinding);
//create a new header row
GridViewRow row = base.CreateRow(-1, -1, DataControlRowType.Header,
DataControlRowState.Normal);
//convert the exisiting columns into an array and initialize
DataControlField[] fields = new DataControlField[this.Columns.Count];
this.Columns.CopyTo(fields, 0);
this.InitializeRow(row, fields);
// perform any manipulations with cells that you think are appropriate
// for example, you will need to add colspan attribute to cells 1 and 3,
change their captions, and remove cells 2 and 4
Table table = (Table)this.Controls[0];
table.Rows.AddAt(0, row);
return result;
}

Hope this helps
"tirath" wrote:
Quote:
hi,
I want to display data in on my web page, in gridview in this format:
Group A Group B
A1 A2 B1 B2
Test 1 1 2 1 2
Test 2 1 2 1 2
>
Group A is header to columns A1 and A2 and Group B is header to
columns B1 and B2.
How do i add header to columns A1 A2 and B1 B2?
>
I am using ASP.Net 2.0. Please help me. Is it possible with some other
control instead of gridview?
>
Thanks
>
>
  #4  
Old August 20th, 2007, 09:46 AM
Eliyahu Goldin
Guest
 
Posts: n/a

re: Multi column header gridview | ASP.Net 2.0


You can use a repeater like this:

<asp:repeater>
<asp:headertemplate>
<table>
<tr>
<td colspan=2>Group A</td>
<td colspan=2>Group B</td>
</tr>
<tr>
<td>A1</td>
<td>A2</td>
<td>B1</td>
<td>B2</td>
</tr>
</asp:headertemplate>
<asp:itemtemplate>
<tr>
....
</tr>
</asp:itemtemplate>
<asp:footertemplate>
</table>
</asp:footertemplate>
</asp:repeater>

--
Eliyahu Goldin,
Software Developer
Microsoft MVP [ASP.NET]
http://msmvps.com/blogs/egoldin
http://usableasp.net


"tirath" <Tirath.g@hotmail.comwrote in message
news:1187551266.560608.193010@w3g2000hsg.googlegro ups.com...
Quote:
hi,
I want to display data in on my web page, in gridview in this format:
Group A Group B
A1 A2 B1 B2
Test 1 1 2 1 2
Test 2 1 2 1 2
>
Group A is header to columns A1 and A2 and Group B is header to
columns B1 and B2.
How do i add header to columns A1 A2 and B1 B2?
>
I am using ASP.Net 2.0. Please help me. Is it possible with some other
control instead of gridview?
>
Thanks
>

  #5  
Old August 20th, 2007, 12:56 PM
marss
Guest
 
Posts: n/a

re: Multi column header gridview | ASP.Net 2.0


On 19 , 22:21, tirath <Tirat...@hotmail.comwrote:
Quote:
hi,
I want to display data in on my web page, in gridview in this format:
Group A Group B
A1 A2 B1 B2
Test 1 1 2 1 2
Test 2 1 2 1 2
>
Group A is header to columns A1 and A2 and Group B is header to
columns B1 and B2.
How do i add header to columns A1 A2 and B1 B2?
>
I am using ASP.Net 2.0. Please help me. Is it possible with some other
control instead of gridview?
>
Thanks
Look here:
http://marss.co.ua/MergingGridViewHeaderColumns.aspx

Regards, Mykola

Closed Thread


Similar Threads
Thread Thread Starter Forum Replies Last Post
How to delete multiple rows in a GridView? Michael answers 2 June 27th, 2008 09:03 PM
Wrap listview column header Marco answers 2 July 18th, 2006 02:45 PM
Dynamic titles for datagrid columns Patrick answers 1 November 19th, 2005 10:08 PM
Can multi queries be done in ASP pages? Lord Merlin answers 3 July 19th, 2005 01:12 PM