2011-10-28 15 views
9

誰かがJQueryであるタブから別のタブに変更するときにイベントを発生させる方法を知っていますか?例えばJQuery onchange in tabイベント

<li><a href="#tab-1" onclick="submitForm();" onchange="myJSHere();">Tab</a></li> 
+1

のjQuery UIのタブウィジェット?あなたのJavaScriptコードは構文的に意味をなさない。 – pimvdb

+4

あなたはここで新しいものではありません。詳細を知り、あなたが望むものを正確に定義することを知っておく必要があります。 –

答えて

25

のjQuery UI ???私にとって

$("#tabs").tabs({ 
    select: function(event, ui) { 
     alert("PRESSED TAB!"); 
    } 
}); 
+0

このコールバックは、実際のタブ変更イベントが発生する前*に発生します。私は実際のコールバックをsetTimeoutにラップすることでこの問題を回避する必要がありました:( – hughes

+4

アニメーションが完了した後に起動するDOCSの中で、 "activate"イベントを使用する可能性があります;-) –

+1

をテストしました。選択しないでください。 –

9
$(function() { 
    $("#tabs").tabs({ activate: function(event ,ui){ 
        //console.log(event); 
        //alert( ui.newTab.index()); 
     alert(ui.newTab.attr('li',"innerHTML")[0].getElementsByTagName("a")[0].innerHTML); 
     //alert(this.text); 
       } }); 
2

作業

HTML:

<div id="tabs"> 
    <ul class="nav nav-tabs"> 
     <li class="active"><a data-toggle="tab" href="#home">Home</a></li> 
     <li><a data-toggle="tab" href="#menu1">Menu 1</a></li> 
     <li><a data-toggle="tab" href="#menu2">Menu 2</a></li> 
    </ul> 

    <div class="tab-content"> 
     <div id="home" class="tab-pane fade in active"> 
      <h3>HOME</h3> 
      <p>Some content.</p> 
     </div> 
     <div id="menu1" class="tab-pane fade"> 
      <h3>Menu 1</h3> 
      <p>Some content in menu 1.</p> 
     </div> 
     <div id="menu2" class="tab-pane fade"> 
      <h3>Menu 2</h3> 
      <p>Some content in menu 2.</p> 
     </div> 
    </div> 
</div> 

スクリプト

<script src="https://code.jquery.com/ui/1.12.0/jquery-ui.js"></script> 
<script> 
    $("#tabs").tabs({ 
     activate: function(event, ui) { 
      alert("PRESSED TAB!"); 
     } 
    }); 
</script>