0

動作させようとしているこのよく知られたスクリプトがあります。現時点ではすべて正常に動作しますが、ページを最初に開くと最初のタブが表示されますが、2 番目のタブを表示する必要があります。 . (1 つ目は単なるメール作成タブで、2 つ目は実際の受信トレイです)

ここにジャバスクリプトがあります

    <script type="text/javascript">

$(document).ready(function() {

    //Default Action
    $(".tab_content").hide(); //Hide all content
    $("ul.tabs li:first").addClass("active").show(); //Activate first tab
    $(".tab_content:first").show(); //Show first tab content

    //On Click Event
    $("ul.tabs li").click(function() {
        $("ul.tabs li").removeClass("active"); //Remove any "active" class
        $(this).addClass("active"); //Add "active" class to selected tab
        $(".tab_content").hide(); //Hide all tab content
        var activeTab = $(this).find("a").attr("href"); //Find the rel attribute value to identify the active tab + content
        $(activeTab).fadeIn(); //Fade in the active content
        return false;
    });

});

</script>

そして、ここにタブのhtmlがあります

> <ul class="tabs">
>     <li><a href="#compose" class="compose"></a></li>
>     <div id="mail_sidebar_top">
>         <li><a href="#inbox" class="inbox">Inbox(0)</a></li>
>         <li><a href="#sent_mail" class="sent_mail">Sent Mail(0)</a></li>
>         <li><a href="#trash" class="trash">Trash(0)</a></li>
>         <li><a href="#reported" class="reported">Reported</a></li>
>         <li><a href="#drafts" class="drafts">Drafts</a></li>
>         
>     </div><!---end mail_sidebar_top--->
>     
>     <div id="mail_sidebar_middle">
>         <li><a href="#notifications" class="notifications">Notifications</a></li>
>         <li><a href="#alerts" class="alerts">Alerts</a></li>
>         
>     </div><!---end mail_sidebar_top--->
>    
>     </ul>

助けてくれてありがとう

4

2 に答える 2

3

2 番目のタブを表示するには、これらの行を変更します

   $("ul.tabs li:eq(1)").addClass("active").show(); //Activate second tab
   $(".tab_content:eq(1)").show(); //Show second tab content

基本的に、現在のバージョンでは、ページが読み込まれるときに、jQuery セレクターに基づいてアクティブなタブのコンテンツとクラスを追加します。最初のインスタンス (つまり ) にセレクターを使用するのではなく、html コンテンツがタブと同じ順序になっているため、:firstそれを に変更できます:eq(1)。(この場合は 1 つです。jquery は配列内の DOM 要素を参照するため、最初のタブはインデックス 0 にあり、2 番目のタブはインデックス 1 にあります)。開始時に別のタブを表示するには、n を必要なタブの配列インデックスに変更:eq(1)するだけです。:eq(n)

編集さらに良い解決策は、jQuery によって提供される実際の eq() 関数を使用することです。これにより、パフォーマンスが向上します。

   $("ul.tabs li").eq(1).addClass("active").show(); //Activate second tab
   $(".tab_content").eq(1).show(); //Show second tab content
于 2012-08-03T19:22:02.857 に答える
-1
$(".tabs").tabs({
    selected: 1
});

ここには多くのオプションがあります。

于 2012-08-03T17:41:44.130 に答える