使用 HREF ID 滚动到顶部
scroll to top using href id
我想将div滚动到顶部位置。我在获取 href 值时遇到问题。现在"a"返回未定义的console.log(a);
function myFunction()
{
var a=$(this).attr('href');
console.log(a);
$('html, body').animate({scrollTop: $('#'+a).offset().top-40}, 500);
}
#consulting,#segments,#partner,#insights{min-height:100vh;}
.secMenu{position:fixed;
}
<div class="container-fluid">
<div class="row secMenu">
<div class="col-md-9 col-sm-12 menu">
<ul class="nav navMenu">
<li class="test1"><a href="#consulting" onclick="myFunction()">Consulting & Solutions</a></li>
<li class="test2"><a href="#segments" onclick="myFunction()">Segments</a></li>
<li class="test3"><a href="#partner" onclick="myFunction()">Our Partners</a></li>
<li class="test4"><a href="#insights" onclick="myFunction()">Perspectives</a></li>
</ul>
</div>
</div> <!--End of second menu -->
<div class="row">
<div id="consulting">
div1
</div>
<div id="segments">
div11
</div>
<div id="partner">
div111
</div>
<div id="insights">
div1111
</div>
</div>
</div>
我已经为您使用了的做了一个替代方案,但它做同样的事情。我删除了您使用的函数,改用了jQuery。希望我的答案对您有用:
$('.nav li a').on('click', function(e) {
e.preventDefault();
var a = $(this).attr('href');
$('html, body').animate({
scrollTop: $(a).offset().top
}, 500);
});
#consulting,
#segments,
#partner,
#insights {
min-height: 100vh;
}
.secMenu {
position: fixed;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="container-fluid">
<div class="row secMenu">
<div class="col-md-9 col-sm-12 menu">
<ul class="nav navMenu">
<li class="test1"><a href="#consulting">Consulting & Solutions</a>
</li>
<li class="test2"><a href="#segments">Segments</a>
</li>
<li class="test3"><a href="#partner">Our Partners</a>
</li>
<li class="test4"><a href="#insights">Perspectives</a>
</li>
</ul>
</div>
</div>
<!--End of second menu -->
<div class="row">
<div id="consulting">
div1
</div>
<div id="segments">
div11
</div>
<div id="partner">
div111
</div>
<div id="insights">
div1111
</div>
</div>
</div>
要查看它的实际效果,您可以点击上面的"运行代码片段"按钮,或者您可以在此处看到一个小提琴。
因为默认情况下this
绑定到全局对象(在浏览器中它是window
)。
您可以尝试将this
传递给myFunction()
,如下所示:myFunction(this)
。在myFunction
定义中:function myFunction(target) {...}
,target
现在指的是锚元素。
相关文章:
- 单击顶部导航时如何进行向下滚动效果(向下滑动).
- 背景图像顶部的滚动图像不移动
- 滚动然后捕捉到顶部而不是取消捕捉
- 如何在从顶部滚动时暂停转盘/滑块,并在滚动到顶部时重新开始
- Android默认浏览器:谷歌地图制作“;位置:相对;元素在页面顶部滚动
- 如何将“切换滑块内容”的顶部滚动到视口的中心
- 修复了在页面顶部滚动时居中导航的问题
- 每次在顶部滚动顶部重置
- 为什么有时滚动顶部/滚动左不可写
- 当目标处于顶部滚动状态时,如何从菜单中激活项目
- 请在顶部滚动一次
- 当用户从顶部滚动超过一定距离时,执行Javascript
- 向表格添加水平顶部滚动条的Aurelia方式
- 如何使文档(页面)向左和顶部以及相对于正文的滚动(向左和顶部滚动)
- 从导航底部而非页面顶部滚动至Div
- 顶部滚动-可替代preventDefault()函数
- “无限scroll"代码只适用于顶部滚动
- 当导航栏固定顶部滚动时,引导捕获
- 单击时从窗口顶部滚动到特定位置
- 花式框弹出窗口始终在顶部滚动