1

在我添加第四个 jQuery 选项卡之前,我有一个简单的 asp.net 网页可以正常工作。无论我在第 4 个选项卡上放置什么内容,都不会呈现任何内容。

在搜索了大约十几个 SO 帖子后,我想我在这里找到了一个解决方案:Jquery flowplayer - tabs - content inside div tags not displayed ... but still can't get it to work。

我是 jQuery、JavaScript 和 asp 的新手,所以要温柔 :)

在此先感谢您的时间。

 <div class="tabWrapper">
        <div id="tabs">
            <ul>
                <li><a href="#tabs-1"><span>Current Status</span></a></li>
                <li><a href="#tabs-2"><span>Budget vs. Actual</span></a></li>
                <li><a href="#tabs-3"><span>Projected Expense</span></a></li>
                <li><a href="#tabs-4"><span>Expense History</span></a></li>
            </ul>
            <div id="tabs-1">
                <br />
                <asp:Panel ID="pnlNoDataFound" runat="server">No data available at this time.</asp:Panel>
                <asp:GridView ID="expenditureSummaryGrid" class="multiRowCashTable" runat="server"></asp:GridView>
            </div>    <%--close tab 1--%>
            <div id="tabs-2" >
                <div class="buttonContainer"><button class="balanceButton" onclick="toggleButton('balance'); return false;" title="Help">Hide Balance Table</button></div>
                <asp:GridView ID="balanceGrid" class="multiRowCashTable" runat="server"></asp:GridView>  
                <div class="buttonContainer"><button class="expenseButton" onclick="toggleButton('expense'); return false;" title="Help">Show Expense Table</button></div>
                <asp:GridView ID="expenseGrid" class="multiRowCashTable" runat="server"></asp:GridView>
                <div class="buttonContainer"><button class="budgetButton" onclick="toggleButton('budget'); return false;" title="Help">Show Budget Table</button></div>
                <asp:GridView ID="budgetGrid" class="multiRowCashTable" runat="server"></asp:GridView> 
            </div>    <%--Close Tab 2--%>
            <div id="tabs-3">
                <asp:Panel ID="divProjectionHeader" runat="server">                
                    <table class="tblProjectHeader">
                        <tr>
                            <td><asp:label ID="Label1" class="makeBold" runat="server" >Current Award Year: </asp:label><asp:label id="lblCurrAwardYear" runat="server" ></asp:label></td>
                            <td><asp:label ID="Label2" class="makeBold" runat="server" >Months Remaining: </asp:label><asp:label id="lblRemainingMonths" runat="server" ></asp:label></td>
                            <td><asp:label ID="Label3" class="makeBold" runat="server" >Burn Rate Months: </asp:label>
                                <asp:DropDownList id="selBurnRateMonths"
                                    AutoPostBack="True"
                                    EnableViewState="True"
                                    runat="server">
                                    <asp:ListItem Selected="True" Value="12">12</asp:ListItem>
                                    <asp:ListItem Value="9">9</asp:ListItem>
                                    <asp:ListItem Value="6">6</asp:ListItem>
                                    <asp:ListItem Value="4">4</asp:ListItem>
                                    <asp:ListItem Value="3">3</asp:ListItem>
                                    <asp:ListItem Value="2">2</asp:ListItem>
                                    <asp:ListItem Value="1">1</asp:ListItem>                        
                                </asp:DropDownList>
                            </td>
                            <td><asp:label ID="Label4" class="makeBold" runat="server" >Months Included:</asp:label><asp:label id="lblBurnRateMonths" runat="server" ></asp:label></td>
                        </tr>
                    </table>                                     
                </asp:Panel>
                <br /><br />
                <asp:Panel ID="pnlProjection" runat="server"></asp:Panel>
                <br />
                <asp:Panel ID="divCalc" runat="server">
                    <button id="calcButton" onclick="calcAdjustedBalance(); return false;"  >Calc</button>
                    <button id="zeroButton" onclick="calcZero(); return false;"  >Zero</button>
                    <button id="resetButton" onclick="resetForm(); return false;"  >Reset</button>
                </asp:Panel>
            </div>    <%--Close tab 3--%>
            <div id="tabs-4" >
                <p>Hello</p>
            </div>    <%--Close tab 4--%>
        </div>    <%--Close tabs--%>        
    </div>  <%--Close Tab Wrapper--%>

初始化逻辑:

    // On Doc Ready
    $(document).ready(function () {

        // Config Tabs
        $(function () {
            $('#tabs').tabs();
        });  // End Config Tabs

不确定这是否有帮助,但是在添加第四个选项卡之前,我注意到了奇怪的索引行为。我使用选择来动态更改打开的初始选项卡:

    If IsPostBack Then

        Dim SenderName As String
        SenderName = clsWebUtil.GetPostBackControl(Me)

        If SenderName = "selBurnRateMonths" Then
            hfSelectedTab.Value = 3
        Else
            hfSelectedTab.Value = 0
        End If

    End If

奇怪的是,索引必须是“3”才能访问第三个选项卡。由于它们是从零开始的,我认为它应该是索引“2”。也许“tabs-2”上的嵌入式 div 会导致问题?

4

1 回答 1

0

我有同样的问题。在玩了几个小时之后,结果发现它是嵌套的div,并且 jQueryAccordion以某种方式弄乱了最后一个选项卡。我最终将我最后一个选项卡的标记移动到第一个选项卡的顶部。在你的情况下,它会像

<div id="tabs-4" >
   <p>Hello</p>
</div>
<div id="tabs-1">
   <br />
   <asp:Panel ID="pnlNoDataFound" runat="server">No data available at this time.</asp:Panel>
   <asp:GridView ID="expenditureSummaryGrid" class="multiRowCashTable" runat="server"></asp:GridView>
</div>

请注意,在运行时,选项卡将以与列表相同的顺序显示:

<ul>
   <li><a href="#tabs-1"><span>Current Status</span></a></li>
   <li><a href="#tabs-2"><span>Budget vs. Actual</span></a></li>
   <li><a href="#tabs-3"><span>Projected Expense</span></a></li>
   <li><a href="#tabs-4"><span>Expense History</span></a></li>
</ul>

所以移动标记不会改变顺序。

于 2014-11-26T21:48:43.890 回答