3

好的,所以希望这是关于 Bootstrap Scrollspy 的最后一个问题,几乎就在那里,我希望再解决一个问题。正如我所读到的,拥有 100% 的身体似乎不同意 scrollspy (我使用粘性页脚)。无论我在页面上的哪个位置,都会突出显示导航中的最后一个元素。

I have tried removing 100% body
I have tried removing the scrollspy js
I have tried setting the body as the target element
I have tried $('body').scrollspy();

这些都不起作用。如果我在我正在监视的元素上设置了高度,那么它确实可以工作,尽管它似乎滚动了很多目标元素然后改变了。我希望仍然能够保持粘性页脚。

这是我的代码

看法

<div class="container">
 <div class="row show-grid clear-both">
  <div id="left-sidebar" class="span3 sidebar">
    <div class="side-nav sidebar-block">
     <div id="dateNav">
      <h3 class="resultTitle fontSize13">Release Dates</h2>
       <ul class="nav date">
        <% @response.each_pair do |date, movie| %>
        <li><i class="icon-chevron-right"></i><%= link_to date_format(date), "#d_#{date}", :id=> '#d_#{date}' %></li>
        <% end %>
      </ul>
     </div>
    </div>
  </div>
<div class="span9">
  <div id="spyOnThis" data-spy="scroll" data-target="#dateNav">
   <% @response.each_pair do |date, movie| %>
    <h3 class="resultTitle fontSize13" id="d_<%= date %>">Available on&nbsp;<%= date_format(date) %></h3>
    <% movie.each do |m| %>
      <div class="thumbnail clearfix">
        <!--Image here
    <% end %>>
        <div class="caption pull-right">
          <!--Content Here
        </div>
      </div>
    <% end %>
  <% end %>
  </div>
</div><!--span9-->
</div><!--Row-->
</div><!--/container-->

JS

$('#dateNav').scrollspy();

CSS

#dateNav{
position: fixed;
}

#spyOnThis {
height:100%;
overflow:auto;
}

.side-nav .active a {
 color: #FFBE00;
}

HTML 输出(导航)

  <div id="left-sidebar" class="span3 sidebar">
   <div class="side-nav sidebar-block">
    <div id="dateNav">
     <h3 class="resultTitle fontSize13">Release Dates</h3>
     <ul class="nav date">
    <li><i class="icon-chevron-right"></i>
    <a id="#d_#{date}" href="#d_2013-01-09">9th Jan 2013</a>
    </li>
    <li><i class="icon-chevron-right"></i>
    <a id="#d_#{date}" href="#d_2013-01-11">11th Jan 2013</a>
  </li>
  <li class="active"><i class="icon-chevron-right"></i>
  <a id="#d_#{date}" href="#d_2013-01-30">30th Jan 2013</a>
  </li>
  </ul>
  </div>
 </div>
 </div>

被监视的元素

<div class="span9">
 <div id="spyOnThis" data-target="#dateNav" data-spy="scroll">

  <h3 id="d_2013-01-09" class="resultTitle fontSize13">Available on 9th Jan 2013</h3>
   <div class="thumbnail clearfix">
    <!--Image Here -->
    <div class="caption pull-right">
     <!--Paragraphs in here -->
    </div>
   </div>

    <h3 id="d_2013-01-11" class="resultTitle fontSize13">Available on 11th Jan 2013</h3>
     <div class="thumbnail clearfix">
    <!--Image Here -->
     <div class="caption pull-right">
    <!-Paragraphs here
     </div>
    </div>

     <div class="thumbnail clearfix">
      <!-- Image Here-->
      <div class="caption pull-right">
       <!-paragraphs here -->
      </div>
    </div>

     <div class="thumbnail clearfix">
      <!-- Image Here-->
      <div class="caption pull-right">
       <!-paragraphs here -->
      </div>
    </div>

     <h3 id="d_2013-01-09" class="resultTitle fontSize13">Available on next date</h3>
   <div class="thumbnail clearfix">
    <!--Image Here -->
    <div class="caption pull-right">
     <!--Paragraphs in here -->
    </div>
   </div>
   </div>
   </div>

为代码量道歉,但我猜最好有更多代码

那么有没有人知道这个的解决方案,因为scrollspy目前看起来确实很麻烦

谢谢

4

3 回答 3

4

您根本无法在使用 ScrollSpy 监视的元素上设置 100% 高度,无论它bodydiv.
但是,GitHub 上有一个问题建议解决此问题(也在此处讨论)。

在您的情况下,这将是:

$(window).scrollspy({wrap: $('#spyOnThis')[0]});


这是适用于该修复程序的代码的 jsFiddle 。请注意,我更改了您的一些 HTML:

  • 我再次删除了data-targetanddata-spy属性。启动 ScrollSpy 时,使用数据属性JavaScript。
  • 我给了你的span9div #spyOnThisID,因为额外的标记是不必要的。

希望这将一劳永逸地解决它。

编辑

该解决方案有效;对于@Richlewis 的特定场景,我们需要将参数添加offset: -250到 ScrollSpy。

于 2013-01-25T18:59:48.350 回答
0

我刚刚在我正在构建的网站上工作。我遇到了同样的问题,总是突出显示最后一个元素。.scrollspy()我的问题是当它应该在身体上时我正在调用nav 元素。

尝试将您的脚本调用更改为:

$('body').scrollspy();
于 2013-01-25T18:34:07.957 回答
0

如果其他答案对您不起作用,我的问题最终是页面顶部缺少文档类型。

Scrollspy 调用$(window).height()公式计算当前滚动位置。 从this other question,您可以看到如果没有正确的文档类型,此调用将不起作用。

一旦我添加<!DOCTYPE html>到我的 HTML 顶部,Scrollspy 就开始突出显示正确的链接。

于 2016-12-28T21:40:31.393 回答