5

以下は私のコードですが、タブから取り出したときに正常に動作するため、何も問題がないことはわかっています。問題を引き起こしている可能性があると思われる重複したIDもありません。とにかく、誰かが素晴らしいアイデアや回避策を持っていれば!

<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>        
4

2 に答える 2

10

これは Bootstrap のバグではありません。ページが読み込まれると、scrollspy 要素を含むタブが非表示になります。そのため、scrollspy プラグインがスクロール div 内$.position()でそれぞれの を見つけようとすると、 return が呼び出されます。スクロールするとちらつきが見えるのはそのためです。プラグインは、すべてのスクロール ターゲットが同じ位置にあると認識します。<h4 id="foo">{top: 0, left: 0}

scrollspy プラグインのドキュメントを見ると、DOM から要素を追加または削除する場合.scrollspy('refresh')、プラグインがさまざまなスクロール ターゲットの位置を再評価できるように、関数を呼び出す必要があることが記載されていることがわかります。

つまり、scrollspy コンテンツを含むタブが読み込まれるまで待ってから、refresh 関数を呼び出す必要があります。また、すべての個別のクリック ハンドラーを 1 つのハンドラーに結合したことに注意してください。

$(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'); 
            });
        }
    });
});

data-offset="300"また、要素に属性を使用するのではなく、要素のを CSSで<div id="scrollspy-example">設定する必要があります。positionrelative

#scrollspy-example {
    position: relative;
}

動作するjsFiddleデモは次のとおりです。

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

于 2012-07-11T15:25:41.767 に答える
1

Adding:

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

after the:

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

makes sure that the correct position is updated as you load this particular tab. Otherwise the wrong li element will be highlighted by scrollspy until you move/start scrolling, causing the refresh. The 'process' line performs this on tab load.

于 2012-08-27T18:52:55.140 に答える