0

私はjqueryにかなり慣れていないので、jquery tabberを構築することにしました。ここまでは順調ですが、少し問題があります!!! URL に基づいてタブバーをアクティブにする方法がわかりません。たとえば、リンクが www.myweb.com#tab2 の場合、2 番目の tabber がアクティブになります。私のjqueryは次のとおりです。

$(document).ready(function() {

    // When page loads...
    $(".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 href attribute value to identify the active tab + content
        $(activeTab).fadeIn(); //Fade in the active ID content
        return false;
    });

});

およびHTMLリストは次のとおりです

<ul class="tabs">
    <li><a href="#tab1">Design Team</a></li>
    <li><a href="#tab2">Publications</a></li>
    <li><a href="#tab3">Awards &amp; Recognitions</a></li>
    <li><a href="#tab4">Our Mission</a></li>
    <li class="last-item"><a href="#tab1">Company Profile</a></li>
</ul>

誰かがこのリンクを使用して私のウェブサイトにアクセスしたときにwww.mywebsite.com#tab3、tab3 を有効にしたいと考えています。jquery tabber にはこれがあることは知っていますが、自分の jquery tabber でこれを達成する方法がわかりません。どんな助けでも大歓迎です

4

2 に答える 2

0

hrefに等しい属性を持つアイテムをアクティブにしますlocation.hash:

$(document).ready(function () {
   var hash = location.hash;
   $(".tab_content").hide(); //Hide all content
   if ($("ul.tabs li a[href='" + hash + "']").length) { //check if such link exists
      $("ul.tabs li a[href='" + hash + "']").parent().addClass("active"); //Activate tab
      $(hash).show();
   }
   else {
      $("ul.tabs li:first").addClass('active');
      $(".tab_content:first").show()
   }       
}
于 2013-03-29T13:31:44.107 に答える
0

ものすごく単純。trigger clickハッシュ インデックスに基づいてイベントを実行できます。

これはあなたのために働くでしょう。たとえば tab3 をクリックした後にページを更新し、URL に hash index が含まれている#tab3場合、3 番目のタブが自動的にフォーカスされます。

orタグとそのビオラ にid tab1tab2、があると仮定します。これらのコードに影響を与えずに既存のコードに追加すれば完了です。tab3tab4lia

$(function(){
    if(location.href.indexOf('#') != -1){
        var namedAnchor = window.location.hash;
        var findToTab = namedAnchor;
        $(findToTab).trigger('click');
    }
});

編集: いずれかまたはタグに
IDを割り当てたくない場合は、これを行うことができます。lia

$(function(){
    if(location.href.indexOf('#') != -1){
        var namedAnchor = window.location.hash;
        var findToTab = namedAnchor;
        $("ul.tabs li a[href='" + findToTab + "']").trigger('click');
    }
});
于 2013-03-29T15:24:27.630 に答える