Bootstrap 3 tab/navbarと文字通り all google spat outのタブ変更が間違っていた/うまくいかなかった場合、私は非現実的な時間をかけて関数を起動しようとしました。
これをどうやってやるの?
メタ編集:コメントを見る
$('a[data-toggle="tab"]').on('shown.bs.tab', function (e) {
var target = $(e.target).attr("href") // activated tab
alert(target);
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" rel="stylesheet"/>
<ul id="myTab" class="nav nav-tabs">
<li class="active"><a href="#home" data-toggle="tab">Home</a></li>
<li class=""><a href="#profile" data-toggle="tab">Profile</a></li>
</ul>
<div id="myTabContent" class="tab-content">
<div class="tab-pane fade active in" id="home">
home tab!
</div>
<div class="tab-pane fade" id="profile">
profile tab!
</div>
</div>
$(function () {
$('#myTab a:last').tab('show');
});
$('a[data-toggle="tab"]').on('shown.bs.tab', function (e) {
var target = $(e.target).attr("href");
if ((target == '#messages')) {
alert('ok');
} else {
alert('not ok');
}
});
問題は、attr( 'href')が空になることがないことです。
または#id = "#some value"を比較してからajaxを呼び出します。
@ Gerbenの投稿のおかげで、ドキュメントで説明されているように2つのイベントshow.bs.tab(タブが表示される前)とshows.bs.tab(タブが表示された後)があることがわかりました - Bootstrapタブ 用法
特定のタブだけに興味があり、1つの関数にif - elseブロックを追加せずに別の関数を追加する場合の追加の解決策は、a hrefセレクタを使用することです(おそらく必要に応じて追加のセレクタと共に)。
$("a[href='#tab_target_id']").on('shown.bs.tab', function(e) {
console.log('shown - after the tab has been shown');
});
// or even this one if we want the earlier event
$("a[href='#tab_target_id']").on('show.bs.tab', function(e) {
console.log('show - before the new tab has been shown');
});
Mosh Feuの回答に追加するには、タブが私の場合のようにその場で作成された場合、次のコードを使用します。
$(document).on('shown.bs.tab', 'a[data-toggle="tab"]', function (e) {
var tab = $(e.target);
var contentId = tab.attr("href");
//This check if the tab is active
if (tab.parent().hasClass('active')) {
console.log('the tab with the content id ' + contentId + ' is visible');
} else {
console.log('the tab with the content id ' + contentId + ' is NOT visible');
}
});
これが誰かに役立つことを願っています
これは私のために働きました。
$('.nav-pills > li > a').click( function() {
$('.nav-pills > li.active').removeClass('active');
$(this).parent().addClass('active');
} );
私は別の方法を使います。
a
がいくつかの サブストリング から始まるすべてのid
を見つけるようにしてください。
_ js _
$('a[id^=v-photos-tab]').click(function () {
alert("Handler for .click() called.");
});
_ html _
<a class="nav-item nav-link active show" id="v-photos-tab-3a623245-7dc7-4a22-90d0-62705ad0c62b" data-toggle="pill" href="#v-photos-3a623245-7dc7-4a22-90d0-62705ad0c62b" role="tab" aria-controls="v-requestbase-photos" aria-selected="true"><span>Cool photos</span></a>