Problems

When I select a row from the GridView on "TabPanel2", the ActiveTabIndex is not maintained and appears to be reset.

ASPX

<%@ page autoeventwireup="true" codefile="Tabs.aspx.cs" inherits="Tabs" language="C#"
	title="Untitled Page" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
	<title>Untitled Page</title>
</head>
<body>
	<form id="form1" runat="server">
		<aspx:scriptmanager id="ScriptManager1" runat="server">
		</aspx:scriptmanager>
		<ajax:tabcontainer id="TabContainer1" runat="server">
			<ajax:tabpanel id="TabPanel1" runat="server" headertext="TabPanel1">
				<contenttemplate>
				TabPanel1
				</contenttemplate>
			</ajax:tabpanel>
			<ajax:tabpanel id="TabPanel2" runat="server" headertext="TabPanel2">
				<contenttemplate>
				TabPanel2
				<asp:gridview id="GridView1" runat="server" autogenerateselectbutton="true">
				</asp:gridview>
				</contenttemplate>
			</ajax:tabpanel>
		</ajax:tabcontainer>
	</form>
</body>
</html>

CODE-BEHIND

using System;
using System.Collections.Generic;

public partial class Tabs : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
		if (!this.IsPostBack)
		{
			List<int> numbers = new List<int>();

			for (int i = 1; i < 11; i++)
			{
				numbers.Add(i);
			}

			GridView1.DataSource = numbers;
			GridView1.DataBind();
		}
    }
}
 

Solutions

I looked into it. It seems it's caused by not saving client state correctly when the postback is triggered by GridView. My solution is saving it manually.

<%@ Page Language="C#" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<script runat="server">

protected void Page_Load(object sender, EventArgs e)
{
if (!this.IsPostBack)
{
System.Collections.Generic.List<int> numbers = new System.Collections.Generic.List<int>();

for (int i = 1; i < 11; i++)
{
numbers.Add(i);
}

GridView1.DataSource = numbers;
GridView1.DataBind();
}
}
</script>

<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
<title>Untitled Page</title>
<script type="text/javascript">
function OnChanged(sender, args)
{
sender.get_clientStateField().value = sender.saveClientState();
}
</script>

</head>
<body>
<form id="form1" runat="server">
<asp:scriptmanager id="ScriptManager1" runat="server">
</asp:scriptmanager>
<ajaxtoolkit:tabcontainer OnClientActiveTabChanged="OnChanged" id="TabContainer1" runat="server" ActiveTabIndex="0">
<ajaxtoolkit:tabpanel id="TabPanel1" runat="server" headertext="TabPanel1">
<contenttemplate>
TabPanel1
</contenttemplate>
</ajaxtoolkit:tabpanel>
<ajaxtoolkit:tabpanel id="TabPanel2" runat="server" headertext="TabPanel2">
<contenttemplate>
TabPanel2<asp:Button ID="Button1" runat="server" Text="Button" />
<asp:gridview id="GridView1" runat="server" autogenerateselectbutton="True">
</asp:gridview>
</contenttemplate>
</ajaxtoolkit:tabpanel>
</ajaxtoolkit:tabcontainer>
</form>
</body>
</html>