ページのリロード後にTwitterブートストラップで現在のタブをアクティブに保つにはどうすればよいですか?


87

現在TwitterBootstrapでタブを使用しており、ユーザーがデータを投稿してページがリロードされた後、同じタブを選択したいと考えています。

これはどのように行われますか?

タブを開始するための現在の呼び出しは次のようになります。

<script type="text/javascript">

$(document).ready(function() {

    $('#profileTabs a:first').tab('show');
});
</script>

私のタブ:

<ul id="profileTabs" class="nav nav-tabs">
    <li class="active"><a href="#profile" data-toggle="tab">Profile</a></li>
    <li><a href="#about" data-toggle="tab">About Me</a></li>
    <li><a href="#match" data-toggle="tab">My Match</a></li>
</ul>


回答:


138

それを管理するには、localStorageまたはCookieを使用する必要があります。これは大幅に改善できる迅速で汚い解決策ですが、出発点を与えるかもしれません:

$(function() { 
    // for bootstrap 3 use 'shown.bs.tab', for bootstrap 2 use 'shown' in the next line
    $('a[data-toggle="tab"]').on('shown.bs.tab', function (e) {
        // save the latest tab; use cookies if you like 'em better:
        localStorage.setItem('lastTab', $(this).attr('href'));
    });

    // go to the latest tab, if it exists:
    var lastTab = localStorage.getItem('lastTab');
    if (lastTab) {
        $('[href="' + lastTab + '"]').tab('show');
    }
});

素敵な1つの芽、あなたのソリューションはjoomla 30コア、joomlacode.org / gf / project / joomla / tracker
Benn

12
$(this).attr('href')代わりに使用すると$(e.target).attr('id')、完全なURLなしでハッシュが得られます。また、の代わりに.tab()タグにを適用する必要があります。参照:stackoverflow.com/questions/16808205/...data-toggle="tab"$('#'+lastTab)
ベースJobsen

3
Bootstrap 3でメソッドがわずかに shown変更されたようshown.bs.tabです。動作しなくなったようで、に変更する必要がありました。注:私はjavascriptなどを理解しているだけでなく、経済学も理解しています...ですから、何が起きているかを知っている人は、遠慮なく私を訂正してください。
チャズ2013

10
複数のタブコントロール(およびブートストラップ3)で動作するように変更:gist.github.com/brendanmckenzie/8f8008d3d51c07b2700f
ブレンダン

1
最初のタブに移動し、更新後に現在のタブに戻ります
Raviteja 2015

23

これをCookieを使用して機能させ、他のタブやタブペインから「active」クラスを削除し、現在のタブやタブペインに「active」クラスを追加します。

これを行うにはもっと良い方法があると確信していますが、この場合はうまくいくようです。

jQuerycookieプラグインが必要です。

$(function() { 
  $('a[data-toggle="tab"]').on('shown', function(e){
    //save the latest tab using a cookie:
    $.cookie('last_tab', $(e.target).attr('href'));
  });

  //activate latest tab, if it exists:
  var lastTab = $.cookie('last_tab');
  if (lastTab) {
      $('ul.nav-tabs').children().removeClass('active');
      $('a[href='+ lastTab +']').parents('li:first').addClass('active');
      $('div.tab-content').children().removeClass('active');
      $(lastTab).addClass('active');
  }
});

論理的に見えたのに、localStorageソリューションを機能させることができませんでした。このソリューションはすぐに使用でき、$。cookieプラグインは非常に便利です。
Michael J. Calkins 2013

代わりにクラスを削除し、追加のデータトグル=「タブ」とタグに)(.TAB適用するには、以下を参照してください。stackoverflow.com/questions/16808205/...
ベースJobsen

私のレイアウトでは、divに「fadein active」を使用していたため、最後の2行を変更して「inactive」を追加または削除する必要がありました。
obromios 2016

18

他のすべての答えは正しいです。この回答では、複数のページul.nav.nav-pillsまたはul.nav.nav-tabs同じページにある可能性があるという事実が考慮されます。この場合、前の回答は失敗します。

まだ使用してlocalStorageいますがJSON、値として文字列化されています。コードは次のとおりです。

$(function() {
  var json, tabsState;
  $('a[data-toggle="pill"], a[data-toggle="tab"]').on('shown', function(e) {
    var href, json, parentId, tabsState;

    tabsState = localStorage.getItem("tabs-state");
    json = JSON.parse(tabsState || "{}");
    parentId = $(e.target).parents("ul.nav.nav-pills, ul.nav.nav-tabs").attr("id");
    href = $(e.target).attr('href');
    json[parentId] = href;

    return localStorage.setItem("tabs-state", JSON.stringify(json));
  });

  tabsState = localStorage.getItem("tabs-state");
  json = JSON.parse(tabsState || "{}");

  $.each(json, function(containerId, href) {
    return $("#" + containerId + " a[href=" + href + "]").tab('show');
  });

  $("ul.nav.nav-pills, ul.nav.nav-tabs").each(function() {
    var $this = $(this);
    if (!json[$this.attr("id")]) {
      return $this.find("a[data-toggle=tab]:first, a[data-toggle=pill]:first").tab("show");
    }
  });
});

このビットは、すべてのページのアプリ全体で使用でき、タブとピルの両方で機能します。また、タブまたはピルがデフォルトアクティブになっていないことを確認してください。アクティブになっていないと、ページの読み込み時にちらつきの影響が見られます。

重要:親ulがIDを持っていることを確認してください。ありがとうアラン


2
また、BS3の場合、「shown」イベントを「shown.bs.tab」に置き換えます
Alain

18

最良のオプションについては、次の手法を使用してください。

$(function() { 
  //for bootstrap 3 use 'shown.bs.tab' instead of 'shown' in the next line
  $('a[data-toggle="tab"]').on('click', function (e) {
    //save the latest tab; use cookies if you like 'em better:
    localStorage.setItem('lastTab', $(e.target).attr('href'));
  });

  //go to the latest tab, if it exists:
  var lastTab = localStorage.getItem('lastTab');

  if (lastTab) {
    $('a[href="'+lastTab+'"]').click();
  }
});

12

選択したタブをウィンドウのハッシュ値に保存することをお勧めします。これにより、「同じ」ページを表示する同僚にリンクを送信することもできます。秘訣は、別のタブが選択されたときに場所のハッシュを変更することです。ページですでに#を使用している場合は、ハッシュタグを分割する必要がある可能性があります。私のアプリでは、ハッシュ値の区切り文字として「:」を使用しています。

<ul class="nav nav-tabs" id="myTab">
    <li class="active"><a href="#home">Home</a></li>
    <li><a href="#profile">Profile</a></li>
    <li><a href="#messages">Messages</a></li>
    <li><a href="#settings">Settings</a></li>
</ul>

<div class="tab-content">
    <div class="tab-pane active" id="home">home</div>
    <div class="tab-pane" id="profile">profile</div>
    <div class="tab-pane" id="messages">messages</div>
    <div class="tab-pane" id="settings">settings</div>
</div>

<script>
    $('#myTab a').click(function (e) {
        e.preventDefault()
        $(this).tab('show')
    });

    // store the currently selected tab in the hash value
    $("ul.nav-tabs > li > a").on("shown.bs.tab", function (e) {
        var id = $(e.target).attr("href").substr(1);
        window.location.hash = id;
    });

    // on load of the page: switch to the currently selected tab
    var hash = window.location.hash;
    $('#myTab a[href="' + hash + '"]').tab('show');
</script>

この答えをありがとう。それは私にとってはうまく機能し、私はこの問題のためだけにクッキーを扱いたくなかったので、それは素晴らしいことです。
nico008 2013年

@koppor、これは機能しません。ポストバックイベントがあります。リンク<asp:LinkButton CssClass="form-search" ID="LinkButtonSearch" runat="server">Search</asp:LinkButton> ボタンを追加しました。ボタンをクリックすると、現在のタブではなく、デフォルトのタブがアクティブになります。どうすればそれを修正できますか?
ジャマ2014

6

最初のタブでページが点滅し、次にCookieによって保存されたタブが点滅するのを防ぐため(これは、最初のTABでデフォルトでクラスが「アクティブ」であると判断した場合に発生します)

次のようなタブとペインの「アクティブ」クラスを削除します。

<ul class="nav nav-tabs">
<div id="p1" class="tab-pane">

以下のスクリプトを入力して、最初のタブをデフォルトのように設定します(jQuery cookieプラグインが必要です)

    $(function() { 
        $('a[data-toggle="tab"]').on('shown', function(e){
            //save the latest tab using a cookie:
            $.cookie('last_tab', $(e.target).attr('href'));
        });
        //activate latest tab, if it exists:
        var lastTab = $.cookie('last_tab');
        if (lastTab) {
            $('a[href=' + lastTab + ']').tab('show');
        }
        else
        {
            // Set the first tab if cookie do not exist
            $('a[data-toggle="tab"]:first').tab('show');
        }
    });

3

フェージング効果が欲しいですか?@Oktavのコードの更新バージョン:

  1. Bootstrap3の場合
  2. フェードが正しく機能するように、liとtabのdivにクラスを設定します。すべてのコンテンツdivが必要であることに注意してくださいclass="tab-pane fade"

コード:

// See http://stackoverflow.com/a/16984739/64904
// Updated by Larry to setup for fading
$(function() {
  var json, tabsState;
  $('a[data-toggle="pill"], a[data-toggle="tab"]').on('shown.bs.tab', function(e) {
    var href, json, parentId, tabsState;
    tabsState = localStorage.getItem("tabs-state");
    json = JSON.parse(tabsState || "{}");
    parentId = $(e.target).parents("ul.nav.nav-pills, ul.nav.nav-tabs").attr("id");
    href = $(e.target).attr('href');
    json[parentId] = href;
    return localStorage.setItem("tabs-state", JSON.stringify(json));
  });
  tabsState = localStorage.getItem("tabs-state");
  json = JSON.parse(tabsState || "{}");
  $.each(json, function(containerId, href) {
    var a_el = $("#" + containerId + " a[href=" + href + "]");
    $(a_el).parent().addClass("active");
    $(href).addClass("active in");
    return $(a_el).tab('show');
  });
  $("ul.nav.nav-pills, ul.nav.nav-tabs").each(function() {
    var $this = $(this);
    if (!json[$this.attr("id")]) {
      var a_el = $this.find("a[data-toggle=tab]:first, a[data-toggle=pill]:first"),
          href = $(a_el).attr('href');
      $(a_el).parent().addClass("active");
      $(href).addClass("active in");
      return $(a_el).tab("show");
    }
  });
});

3

複数のページにタブがあり、localStorageは前のページのlastTabも保持しているため、次のページでは、前のページのlastTabがストレージにあるため、ここに一致するタブが見つからなかったため、何も表示されませんでした。私はそれをこのように修正しました。

$(document).ready(function(){
    //console.log($('a[data-toggle="tab"]:first').tab('show'))
    $('a[data-toggle="tab"]').on('shown.bs.tab', function () {
        //save the latest tab; use cookies if you like 'em better:
        localStorage.setItem('lastTab', $(this).attr('href'));
    });

    //go to the latest tab, if it exists:
    var lastTab = localStorage.getItem('lastTab');
    if ($('a[href=' + lastTab + ']').length > 0) {
        $('a[href=' + lastTab + ']').tab('show');
    }
    else
    {
        // Set the first tab if cookie do not exist
        $('a[data-toggle="tab"]:first').tab('show');
    }
})

編集:lastTabページごとに異なる変数名を付ける必要があることに気づきました。そうしないと、常に互いに上書きされます。たとえばlastTab_klantenlastTab_bestellingen2つの異なるページでklantenbestellingen両方ともタブにデータが表示されている場合など。

$(document).ready(function(){
    //console.log($('a[data-toggle="tab"]:first').tab('show'))
    $('a[data-toggle="tab"]').on('shown.bs.tab', function () {
        //save the latest tab; use cookies if you like 'em better:
        localStorage.setItem('lastTab_klanten', $(this).attr('href'));
    });

    //go to the latest tab, if it exists:
    var lastTab_klanten = localStorage.getItem('lastTab_klanten');
    if (lastTab_klanten) {
        $('a[href=' + lastTab_klanten + ']').tab('show');
    }
    else
    {
        // Set the first tab if cookie do not exist
        $('a[data-toggle="tab"]:first').tab('show');
    }
})

3

@dgabrielと同様のソリューションで動作するようにしました。この場合、リンク<a>は必要ありませんid。位置に基づいて現在のタブを識別します。

$(function() { 
  $('a[data-toggle="tab"]').on('shown', function (e) {
    var indexTab = $('a[data-toggle="tab"]').index($(this)); // this: current tab anchor
    localStorage.setItem('lastVisitedTabIndex', indexTab);
  });

  //go to the latest tab, if it exists:
  var lastIndexTab  = localStorage.getItem('lastVisitedTabIndex');
  if (lastIndexTab) {
      $('a[data-toggle="tab"]:eq(' + lastIndexTab + ')').tab('show');
  }
});

getItemが表示される前に、コードが間違っていると思います。また、indexTabを2回宣言するという問題もあります。
ジョンマグノリア

@JohnMagnolia私はindexTab2回名前を付けましたが、相違点です。インデックス。だから私は2番目のものを呼びますlastIndexTab。に関してはshown、これはイベントであるため、タブを開くまでトリガーされないため、前であるかどうかは関係ありませんgetItem
ジェイダー2015年

1

次の変更をお勧めします

  1. 以下のようなプラグインを使用しamplify.store crossbrowser /クロスプラットフォームのlocalStorage APIと組み込みフォールバックを提供。

  2. $('#div a[data-toggle="tab"]')この機能を同じページに存在する複数のタブコンテナに拡張するために、保存する必要のあるタブをターゲットにします。

  3. 一意の識別子(url ??)を使用して、最後に使用したタブを複数のページに保存および復元します。


$(function() { 
  $('#div a[data-toggle="tab"]').on('shown', function (e) {
    amplify.store(window.location.hostname+'last_used_tab', $(this).attr('href'));
  });

  var lastTab = amplify.store(window.location.hostname+'last_used_tab');
  if (lastTab) {
    $("#div a[href="+ lastTab +"]").tab('show');
  }
});

1

ローカルストレージのないシンプルなソリューション:

$(".nav-tabs a").on("click", function() {
    location.hash = $(this).attr("href");
});

0

サーバー側のアプローチ。指定されていない場合は、すべてのhtml要素にclass = ""が含まれていることを確認してください。そうでない場合は、nullを処理する必要があります。

    private void ActiveTab(HtmlGenericControl activeContent, HtmlGenericControl activeTabStrip)
    {
        if (activeContent != null && activeTabStrip != null)
        {
            // Remove active from content
            Content1.Attributes["class"] = Content1.Attributes["class"].Replace("active", "");
            Content2.Attributes["class"] = Content2.Attributes["class"].Replace("active", "");
            Content3.Attributes["class"] = Content3.Attributes["class"].Replace("active", "");

            // Remove active from tab strip
            tabStrip1.Attributes["class"] = tabStrip1.Attributes["class"].Replace("active", "");
            tabStrip2.Attributes["class"] = tabStrip2.Attributes["class"].Replace("active", "");
            tabStrip3.Attributes["class"] = tabStrip3.Attributes["class"].Replace("active", "");

            // Set only active
            activeContent.Attributes["class"] = activeContent.Attributes["class"] + " active";
            activeTabStrip.Attributes["class"] = activeTabStrip.Attributes["class"] + " active";
        }
    }

0

初めてページに入るときに最初のタブを表示したい場合は、次のコードを使用してください。

    <script type="text/javascript">
        function invokeMeMaster() {
        var chkPostBack = '<%= Page.IsPostBack ? "true" : "false" %>';
            if (chkPostBack == 'false') {
                $(function () {
                    // for bootstrap 3 use 'shown.bs.tab', for bootstrap 2 use 'shown' in the next line
                    $('a[data-toggle="tab"]').on('shown.bs.tab', function (e) {
                        // save the latest tab; use cookies if you like 'em better:
                        localStorage.setItem('lastTab', $(this).attr('href'));
                    });

                });
            }
            else {
                $(function () {

                    // for bootstrap 3 use 'shown.bs.tab', for bootstrap 2 use 'shown' in the next line
                    $('a[data-toggle="tab"]').on('shown.bs.tab', function (e) {
                        // save the latest tab; use cookies if you like 'em better:
                        localStorage.setItem('lastTab', $(this).attr('href'));
                    });

                    // go to the latest tab, if it exists:
                    var lastTab = localStorage.getItem('lastTab');
                    if (lastTab) {
                        $('[href="' + lastTab + '"]').tab('show');
                    }

                });

            }
        }
        window.onload = function() { invokeMeMaster(); };

    </script>


0

これは、Bootstrap 3jQueryで動作し、さまざまなタブを含むさまざまなURLで機能するスニペットです。ただしページごとに複数のタブをサポートしていませんが、その機能が必要な場合は簡単に変更できます。

/**
 * Handles 'Bootstrap' package.
 *
 * @namespace bootstrap_
 */

/**
 * @var {String}
 */
var bootstrap_uri_to_tab_key = 'bootstrap_uri_to_tab';

/**
 * @return {String}
 */
function bootstrap_get_uri()
{
    return window.location.href;
}

/**
 * @return {Object}
 */
function bootstrap_load_tab_data()
{
    var uriToTab = localStorage.getItem(bootstrap_uri_to_tab_key);
    if (uriToTab) {
    try {
        uriToTab = JSON.parse(uriToTab);
        if (typeof uriToTab != 'object') {
        uriToTab = {};
        }
    } catch (err) {
        uriToTab = {};
    }
    } else {
    uriToTab = {};
    }
    return uriToTab;
}

/**
 * @param {Object} data
 */
function bootstrap_save_tab_data(data)
{
    localStorage.setItem(bootstrap_uri_to_tab_key, JSON.stringify(data));
}

/**
 * @param {String} href
 */
function bootstrap_save_tab(href)
{
    var uri = bootstrap_get_uri();
    var uriToTab = bootstrap_load_tab_data();
    uriToTab[uri] = href;
    bootstrap_save_tab_data(uriToTab);
}

/**
 *
 */
function bootstrap_restore_tab()
{
    var uri = bootstrap_get_uri();
    var uriToTab = bootstrap_load_tab_data();
    if (uriToTab.hasOwnProperty(uri) &&
    $('[href="' + uriToTab[uri] + '"]').length) {
    } else {
    uriToTab[uri] = $('a[data-toggle="tab"]:first').attr('href');
    }
    if (uriToTab[uri]) {
        $('[href="' + uriToTab[uri] + '"]').tab('show');
    }
}

$(document).ready(function() {

    if ($('.nav-tabs').length) {

    // for bootstrap 3 use 'shown.bs.tab', for bootstrap 2 use 'shown' in the next line
    $('a[data-toggle="tab"]').on('shown.bs.tab', function (e) {
        bootstrap_save_tab($(this).attr('href'));
    });
    bootstrap_restore_tab();

    }

});

0

$(document).ready(function(){

        if (JSON.parse(localStorage.getItem('currentClass')) == "active")
        {
            jQuery('#supporttbl').addClass('active')
            $('.sub-menu').css({ "display": "block" });
        }

        $("#supporttbl").click(function () { 
            var currentClass;
            if ($(this).attr('class')== "active") { 

                currentClass = $(this).attr('class');

                localStorage.setItem('currentClass', JSON.stringify(currentClass));
                console.log(JSON.parse(localStorage.getItem('currentClass')));

                jQuery('#supporttbl').addClass('active')
                $('.sub-menu').css({ "display": "block" });

            } else {

                currentClass = "Null"; 

                localStorage.setItem('currentClass', JSON.stringify(currentClass));
                console.log(JSON.parse(localStorage.getItem('currentClass')));

                jQuery('#supporttbl').removeClass('active')
                $('.sub-menu').css({ "display": "none" });

            }  
        });

});


0

ページに複数のタブがある場合は、次のコードを使用できます

<script type="text/javascript">
$(document).ready(function(){
    $('#profileTabs').on('show.bs.tab', function(e) {
        localStorage.setItem('profileactiveTab', $(e.target).attr('href'));
    });
    var profileactiveTab = localStorage.getItem('profileactiveTab');
    if(profileactiveTab){
        $('#profileTabs a[href="' + profileactiveTab + '"]').tab('show');        
    }
    $('#charts-tab').on('show.bs.tab', function(e) {
        localStorage.setItem('chartsactiveTab', $(e.target).attr('href'));
    });
    var chartsactiveTab = localStorage.getItem('chartsactiveTab');
    if(chartsactiveTab){
        $('#charts-tab a[href="' + chartsactiveTab + '"]').tab('show');        
    }     
});
</script>

0

これによりタブが更新されますが、コントローラー内のすべてがロードされた後でのみです。

// >= angular 1.6 angular.element(function () {
angular.element(document).ready(function () {
    //Here your view content is fully loaded !!
    $('li[href="' + location.hash + '"] a').tab('show');
});

0

私はこれをMVCで使用しています:

  • モデルには、POSTメソッドに値を送信するためのSelectedTab整数フィールドがあります

JavaScriptセクション:

<script type="text/javascript">
    $(document).ready(function () {
       var index = $("input#SelectedTab").val();
       $("#tabstrip > ul li:eq(" + index + ")").addClass("k-state-active");

       $("#tabstrip").kendoTabStrip();
    });
    function setTab(index) {
      $("input#SelectedTab").val(index)
    }
</script>

HTMLセクション:

@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
@Html.HiddenFor(model => model.SelectedTab)
<div id="tabstrip">
    <ul>
        <li onclick="setTab(0)">Content 0</li>
        <li onclick="setTab(1)">Content 1</li>
        <li onclick="setTab(2)">Content 2</li>
        <li onclick="setTab(3)">Content 3</li>
        <li onclick="setTab(4)">Content 4</li>
    </ul>
    <div>

    </div>
    <div>

    </div>
    <div>

    </div>
    <div>

    </div>
    <div>

    </div>
</div>
<div class="content">
    <button type="submit" name="save" class="btn bg-blue">Save</button>
</div>
}
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.