2012-07-10 10 views
5

Di seguito è riportato il mio codice, ma so che non c'è nulla di sbagliato in questo, perché funziona correttamente quando si estrae dalla scheda. Non ci sono anche ID duplicati, che pensavo potessero causare il problema. Ad ogni modo, se qualcuno ha idee o soluzioni alternative sarebbe fantastico!Lo scrollstrap di bootstrap non funziona all'interno delle schede?

<div id="sampleNavbar" class="navbar navbar-static"> 
    <div class="navbar-inner"> 
     <div class="container" style="width: auto;"> 
      <a class="brand" href="#">Project Name</a> 
      <ul class="nav"> 
       <li><a href="#PA">PA</a></li> 
       <li><a href="#VT">VT</a></li> 
       <li class="dropdown"> 
        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Dropdown <b class="caret"></b></a> 
        <ul class="dropdown-menu"> 
         <li><a href="#uno">uno</a></li> 
         <li><a href="#dos">dos</a></li> 
         <li class="divider"></li> 
         <li><a href="#tres">tres</a></li> 
        </ul> 
       </li> 
      </ul> 
     </div> 
    </div> 
</div> 
<div id="scrollspy-example" data-spy="scroll" data-target="#sampleNavbar" data-offset="300" style="height: 200px; overflow-y: scroll;"> 
    <h4 id="PA">PA</h4> 
    <p>Ad leggings keytar, brunch id art party dolor labore. Pitchfork yr enim lo-fi before they sold out qui. Tumblr farm-to-table bicycle rights whatever. Anim keffiyeh carles cardigan. Velit seitan mcsweeney's photo booth 3 wolf moon irure. Cosby sweater lomo jean shorts, williamsburg hoodie minim qui you probably haven't heard of them et cardigan trust fund culpa biodiesel wes anderson aesthetic. Nihil tattooed accusamus, cred irony biodiesel keffiyeh artisan ullamco consequat. 
    </p> 
    <h4 id="VT">VT</h4> 
    <p>Veniam marfa mustache skateboard, adipisicing fugiat velit pitchfork beard. Freegan beard aliqua cupidatat mcsweeney's vero. Cupidatat four loko nisi, ea helvetica nulla carles. Tattooed cosby sweater food truck, mcsweeney's quis non freegan vinyl. Lo-fi wes anderson +1 sartorial. Carles non aesthetic exercitation quis gentrify. Brooklyn adipisicing craft beer vice keytar deserunt. 
    </p> 
    <h4 id="uno">uno</h4> 
    <p>Occaecat commodo aliqua delectus. Fap craft beer deserunt skateboard ea. Lomo bicycle rights adipisicing banh mi, velit ea sunt next level locavore single-origin coffee in magna veniam. High life id vinyl, echo park consequat quis aliquip banh mi pitchfork. Vero VHS est adipisicing. Consectetur nisi DIY minim messenger bag. Cred ex in, sustainable delectus consectetur fanny pack iphone. 
    </p> 
    <h4 id="dos">dos</h4> 
    <p>In incididunt echo park, officia deserunt mcsweeney's proident master cleanse thundercats sapiente veniam. Excepteur VHS elit, proident shoreditch +1 biodiesel laborum craft beer. Single-origin coffee wayfarers irure four loko, cupidatat terry richardson master cleanse. Assumenda you probably haven't heard of them art party fanny pack, tattooed nulla cardigan tempor ad. Proident wolf nesciunt sartorial keffiyeh eu banh mi sustainable. Elit wolf voluptate, lo-fi ea portland before they sold out four loko. Locavore enim nostrud mlkshk brooklyn nesciunt. 
    </p> 
    <h4 id="tres">tres</h4> 
    <p>Ad leggings keytar, brunch id art party dolor labore. Pitchfork yr enim lo-fi before they sold out qui. Tumblr farm-to-table bicycle rights whatever. Anim keffiyeh carles cardigan. Velit seitan mcsweeney's photo booth 3 wolf moon irure. Cosby sweater lomo jean shorts, williamsburg hoodie minim qui you probably haven't heard of them et cardigan trust fund culpa biodiesel wes anderson aesthetic. Nihil tattooed accusamus, cred irony biodiesel keffiyeh artisan ullamco consequat. 
    </p> 
    <p>Keytar twee blog, culpa messenger bag marfa whatever delectus food truck. Sapiente synth id assumenda. Locavore sed helvetica cliche irony, thundercats you probably haven't heard of them consequat hoodie gluten-free lo-fi fap aliquip. Labore elit placeat before they sold out, terry richardson proident brunch nesciunt quis cosby sweater pariatur keffiyeh ut helvetica artisan. Cardigan craft beer seitan readymade velit. VHS chambray laboris tempor veniam. Anim mollit minim commodo ullamco thundercats. 
    </p> 
</div>   

risposta

10

Questo non è un bug in Bootstrap. Quello che succede è che, quando la pagina viene caricata, la scheda con gli elementi di scrollspy è nascosta. Pertanto, quando il plugin scrollspy tenta di trovare lo $.position() di ogni <h4 id="foo"> all'interno del proprio div scorrevole, chiama il ritorno {top: 0, left: 0}. Ecco perché vedi lo sfarfallio mentre scorri; il plugin pensa che tutti i tuoi obiettivi di scorrimento si trovino nella stessa posizione.

Se si guarda lo documentation for the scrollspy plugin, si noterà che se si aggiungono o si rimuovono elementi dal DOM, è necessario chiamare la funzione .scrollspy('refresh') in modo che il plugin possa riesaminare le posizioni dei vari obiettivi di scorrimento. .

Detto questo, è necessario attendere fino a quando la scheda con il contenuto dello scrollspy non viene caricata, quindi chiamare la funzione di aggiornamento, in questo modo. Si noti che ho anche combinate di tutti i gestori di scatto separati in un unico gestore

$(function(){ 
    $('.nav-tabs li a').click(function(e) { 
     e.preventDefault(); 
     $(this).tab('show'); 

     // If we are showing the scrollspy tab, let the 
     // plugin refresh itself so it can function properly 
     if(this.id === 'scrotab') { 
      $(this).on('shown',function(){ 
       $('#scrollspy-example').scrollspy('refresh'); 
      }); 
     } 
    }); 
}); 

Inoltre, piuttosto che utilizzare un attributo data-offset="300" sul vostro elemento <div id="scrollspy-example">, è necessario impostare la position dell'elemento da relative con i CSS:

#scrollspy-example { 
    position: relative; 
} 

Ecco una demo jsFiddle che funziona:

http://jsfiddle.net/GyMYE/3/

+0

Grazie mille. È grandioso È buffo perché, a quanto pare, penso che devi avere la lezione di dissolvenza per farlo funzionare. Grazie! – dezman

1

Aggiunta:

$('#scrollspy-example').scrollspy('process'); 

dopo il:

$('#scrollspy-example').scrollspy('refresh'); 

fa in modo che la posizione corretta è aggiornato come si carica questa scheda particolare. Altrimenti l'elemento li sbagliato verrà evidenziato da scrollspy fino a che non ti sposti/inizi a scorrere, causando l'aggiornamento. La linea 'processo' esegue questo carico di tabulazione.

Problemi correlati