AJAX: TabContainer not maintaining ActiveTabIndex between postbacks

 

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>
posted @ 2008-11-21 09:40  KevinWang  阅读(398)  评论(0编辑  收藏  举报