2010-06-24 28 views
1

我想知道如果有人可以帮助我这个。我有三个TabPanels取决于哪个选项卡被点击我想调用一个不同的c#函数来显示不同的内容。我知道我可以在页面加载时运行所有的功能,但这看起来很麻烦。我确信有一种方法可以做到这一点,但我没有多少看。有可能我从错误的角度思考这个问题,所以请让我知道,如果你能想到一个更好的方法来做到这一点。asp.net TabPanel调用后面代码中的代码#

任何帮助将不胜感激!

例ASP.net

<ajaxToolkit:TabContainer ID="tabParameters" AutoPostBack="true" Width="100%" runat="server" ActiveTabIndex="0"> 
<ajaxToolkit:TabPanel ID="tabDetails" OnClientClick="Load_Details()" HeaderText="Details" runat="server"> 

回答

1

我就窝在 “功能” 为WebUserControls并把它们放到不同的TabPanels。他们对Page.Load没有任何帮助,并且是隐形的。定义一个函数“BindData”来完成所有DataBinding /耗时的工作。当用户更改ActiveTab(或默认活动标签)时,使该UserControl可见并调用其BindData函数。

您需要围绕UserControl的UpdatePanels(Updatemode = Conditional)和具有Eventname = ActiveTabChanged的Async-Postback-Trigger,以便只重新加载此面板。

例如在ASPX(MD_Location是用户控件,由于篇幅所限,我只贴一个,但你必须想象他们中的很多):

<act:TabContainer ID="TabContainer1" runat="server" AutoPostBack="true" > 
    <act:TabPanel ID="TabLocation" runat="server" HeaderText="Locations"> 
     <ContentTemplate> 
      <asp:UpdatePanel ID="UpdLocation" runat="server" UpdateMode="Conditional"> 
       <ContentTemplate> 
        <MD:MD_Location id="MD_Location" runat="server" Visible="false" /> 
       </ContentTemplate> 
       <Triggers> 
        <asp:AsyncPostBackTrigger ControlID="TabContainer1" EventName="ActiveTabChanged" /> 
       </Triggers> 
      </asp:UpdatePanel> 
     </ContentTemplate> 
     </act:TabPanel> 

,并在代码隐藏(对不起,只有VB.Net可用的,我希望你的想法):

Private Sub TabContainer1_ActiveTabChanged(ByVal sender As Object, ByVal e As System.EventArgs) Handles TabContainer1.ActiveTabChanged 
     If Me.TabContainer1.ActiveTab Is Me.TabLocation Then 
      Me.MasterDataType = "Locations" 
     End If 
     switchControlVisibility() 
    End Sub 

    Private Sub switchControlVisibility() 
     Select Case Me.MasterDataType.ToLower 
      Case "locations" 
       Me.MD_Location.Visible = True 
       Me.Lblheader2.Text = "Locations" 
       UpdHeader.Update() 
       Me.MD_Location.BindData() '<---- do time-consuming stuff 
       Me.UpdLocation.Update() 

    End Sub 

相关问题