0

我有这个非常有名的脚本,我正在尝试开始工作,目前一切都很好,但是当你第一次打开页面时,它会显示第一个选项卡,正如它应该的那样,我想要的是它显示第二个选项卡. (第一个只是一个邮件撰写选项卡,第二个是实际的收件箱)

这是javascript

    <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

为了显示第二个选项卡,更改这些行

   $("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). (在这种情况下是一个,因为 jquery 引用数组中的 DOM 元素,因此第一个选项卡位于索引 0 处,第二个选项卡位于索引 1 处)。要在开始时显示不同的选项卡,您只需将:eq(1)其中:eq(n)的 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 回答