2014-06-21 13 views
7

Stavo sperimentando le schede che cambiano in modo programmatico con jQuery. Ho provato ad implementare la soluzione fornita da @MasterAM here. Tuttavia, la console Chrome mostra l'errore Uncaught TypeError: undefined is not a functionModifica della scheda Bootstrap 3 attiva utilizzando jQuery

Ecco il mio HTML:

<div id="click-me-div">Click Me</div> 

<ul class="nav nav-tabs"> 
    <li class="active"><a href="#fruits" data-toggle="tab">I like Fruits</a></li> 
    <li><a href="#veggies" data-toggle="tab">I like Veggies Too</a></li> 
    <li><a href="#samosas" data-toggle="tab">But Samosa's Rock</a></li> 
</ul> 

<div class="tab-content"> 
    <div class="tab-pane active" id="fruits">Apple, Kiwi, Watermellon</div> 
    <div class="tab-pane" id="veggies">Kale, Spinach, Pepper</div> 
    <div class="tab-pane" id="samosas">Awesome, Spine Tingling, Explosive</div> 
</div> 

Ed ecco il jQuery:

$(document).ready(function() { 
    $("#click-me-div").click(function() { 
     alert('yes, the click actually happened'); 
     ('.nav-tabs a[href="#samosas"]').tab('show'); 
    }); 
}); 

Il risultato desiderato è che, se faccio clic su "Click Me ", la scheda attiva dovrebbe cambiare nella scheda" samosa ".

Cosa sto sbagliando?

risposta

20

hai lasciato fuori la funzione jQuery

$(document).ready(function() { 
    $("#click-me-div").click(function() { 
     alert('yes, the click actually happened'); 
     $('.nav-tabs a[href="#samosas"]').tab('show'); 
    }); 
}); 

Fiddle

+0

doh! Grazie :) –

+0

Grazie Motti! È semplice e fantastico .. – Gurusinghe

1

Prova questo codice

È possibile utilizzare la funzione onclick() e percorso del nome id scheda.

<a onclick='ActivTab("Security")' class="nav-link" data-toggle="tab" href="#Security" aria-controls="profile" role="tab" id='Security'>Security</a> 


    <script> 
     $(document).ready(function(){ 
      ActivTab('Security'); 
     }); 
     function ActivTab(id){ 
//   $('.nav-tabs a[href="#' + id + '"]').tab('show'); 
      $('.nav-tabs a[href="#' + id + '"]').trigger('click'); 
     }; 
    </script> 
+0

Ciao Ayman, benvenuto in SO! Potrebbe essere una buona idea spiegare cosa sta facendo il tuo frammento e perché hai fatto ciò che hai fatto in modo che i nuovi arrivati ​​trovino più facile capire. –

+0

In primo luogo, grazie per il vostro consiglio. –

Problemi correlati