繁体   English   中英

jQuery滚动到元素不起作用-滚动到随机位置

[英]jquery scroll to element not working - scrolls to random places

关于此有很多stackoverflow问题,但我找不到答案。 我有这个javascript代码:

$(function() {
      $('a[href*=#]:not([href=#])').click(function() {

        $('html,body, .main').animate({
          scrollTop: $(this.hash).offset().top - 10
        }, 1000);

      });
    });

这是我的HTML代码:

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <title>test</title>
    <meta name="viewport" content="width=device-width,initial-scale=1">
    <!--[if gt IE 8]><!--><link rel="stylesheet" href="styles.css"><!--<![endif]-->
    <link rel="stylesheet" href="common.css">
    <script src="responsive-nav.js"></script>
    <script src="//code.jquery.com/jquery-1.10.2.js"></script>
    <script src="//code.jquery.com/ui/1.11.2/jquery-ui.js"></script>
    <script src="scripts/extraScripts.js"></script>

  </head>
  <body>

    <div role="navigation" id="foo" class="nav-collapse">
      <ul>
        <li class="active"><a href="#section1">Inicio</a></li>
        <li><a href="#section2">Equipo</a></li>
        <li><a href="#section3">Sistemas</a></li>
        <li><a href="#section4">Desarrollo</a></li>
      </ul>
    </div>

<div role="main" class="main">

    <a href="#nav" class="nav-toggle">Menu</a>

    <div class = "section" id = "section1" >

        <!-- some stuff -->

    </div> 

    <div class = "section" id = "section2">

        <!-- some stuff -->

    </div>  

    <div class = "section" id = "section3">

      <!-- some stuff -->

    </div>

    <div class = "section" id = "section4" >

            <!-- some stuff -->
    </div>

</div>  

<script>
  var navigation = responsiveNav("foo", {customToggle: ".nav-toggle"});
</script>

  </body>

</html>

因此,我使用的是在网上找到的模板。 它的左侧有一个精美的菜单,中间是一个主要内容。 一切都在里面:

<div role="main" class="main"> </div>

我希望单击菜单上的链接时,它会滚动到特定部分(#section1,#section2,#section3,#section4)。 现在,它在我第一次单击其中一个链接时有效,但是第二次它到达随机位置。

为什么会发生这种情况的任何线索?

-更新-

我尝试了提到的所有解决方案,但没有用。 我认为这与我对主容器(类.main)拥有的CSS有关。 看一下代码(我从正在使用的库中获取了此代码):

.main {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-overflow-scrolling: touch;
  padding: 3em 4em;
  position: fixed;
  overflow: hidden;
  overflow-y: scroll;
  border-top-left-radius: 5px;
  box-shadow: 0 0 15px rgba(0,0,0, .6);
  top: .8em;
  right: 0;
  bottom: 0;
  width: 76%;
  background: #fff;
}

.main::-webkit-scrollbar {
  -webkit-appearance: none;
  background-color: rgba(0,0,0, .15);
  width: 8px;
  height: 8px;
}

.main::-webkit-scrollbar-thumb {
  border-radius: 0;
  background-color: rgba(0,0,0, .4);
}

我试着删除上面的CSS代码并使用它,它的工作原理是:

$(function() {
      $('a[href*=#]:not([href=#])').click(function() {

        $('html,body, .main').animate({
          scrollTop: $(this.hash).offset().top - 10
        }, 1000);

      });
    });

但是我需要那个CSS。 有什么线索可以解决吗?

您的问题是您对链接单击$(this.hash)的上下文有一个奇怪的调用。 在闭包外部更改为that = $(this)解决了这个问题。

$(function() {
  $('a[href*=#]:not([href=#])').click(function() {
    var that = $(this);
    $('html,body, .main').animate({
      scrollTop: that.offset().top - 10
    }, 1000);

  });
});

这是一个柱塞

稍后的!!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM