Javascript 应用transform:translate(X)后,水平滚动菜单粘滞,是否可以检测用户何时滚动回ID?
在我的网站上,我有一个案例研究页面,非常长,有10个部分,所以我想创建一个水平菜单,其中包含指向页面上每个部分的链接。用户将能够为小屏幕设备水平滑动此选项,以便用户可以访问通常位于视口画布之外的链接 我知道如何实现这一切,但我需要的是这个;当用户向下滚动并到达第五个部分时,如果菜单链接稍微偏离右侧的画布,则菜单将向左滑动足够多,以便链接图标显示在最左侧的视口中。反过来,这将把其他链接也带到画布上 但问题是,如果我向滚动菜单容器添加一个类,该类指定一个transform:translate(X)值,并因此在用户到达特定部分时将其设置为左侧动画,则整个菜单将在该点修复,用户不可能手动来回滑动菜单,从那时起访问他们想要的任何菜单链接 我也希望同样的事情反过来发生,这样在上面的触发和菜单向左移动之后,当用户决定向上滚动页面并通过触发初始菜单滑动动作的部分时,它会向右滑动到其原始位置 这种触发菜单幻灯片的行为应该在用户每次或任何时候沿任意方向(向上或向下)滚动超过某个点时发生,但用户仍然可以手动将菜单滑动到任意点 我知道所有这一切都可以使用Javascript实现,但我尝试了很多不同的想法,包括element.scrollintoView,它不起作用,因为在菜单中将其分配给一个ID不会滑动整个菜单。我还尝试通过添加动画类来移动菜单,但也没有成功 更新: 我在代码笔上创建了一个基本示例:Javascript 应用transform:translate(X)后,水平滚动菜单粘滞,是否可以检测用户何时滚动回ID?,javascript,html,css,menu,off-canvas-menu,Javascript,Html,Css,Menu,Off Canvas Menu,在我的网站上,我有一个案例研究页面,非常长,有10个部分,所以我想创建一个水平菜单,其中包含指向页面上每个部分的链接。用户将能够为小屏幕设备水平滑动此选项,以便用户可以访问通常位于视口画布之外的链接 我知道如何实现这一切,但我需要的是这个;当用户向下滚动并到达第五个部分时,如果菜单链接稍微偏离右侧的画布,则菜单将向左滑动足够多,以便链接图标显示在最左侧的视口中。反过来,这将把其他链接也带到画布上 但问题是,如果我向滚动菜单容器添加一个类,该类指定一个transform:translate(X)值
水平滚动菜单
水平滚动菜单
家
新闻
接触
关于
支持
博客
工具
基础
习俗
推荐书
更多
正文,html{
保证金:0;
填充:0;
字体系列:无衬线;
字体大小:16px;
背景色:白色;
}
html{
滚动行为:平滑;
}
包装纸{
显示:块;
宽度:360px;
保证金:0自动;
背景色:黑色;
填充顶部:20px;
}
h1{
字体系列:无衬线;
字体大小:3.5rem;
颜色:白色;
填充:0px 20px;
}
氢{
字体系列:无衬线;
字体大小:2.5rem;
颜色:白色;
}
部分{
宽度:360px;
背景色:透明;
}
.货柜标题{
填充:20px 20px 20px 20px;
}
.集装箱{
填充:200px 40px 200px 40px;
}
div#滚动菜单{
位置:固定;
底部:0;
背景色:#333;
溢出:自动;
空白:nowrap;
宽度:360px;
保证金:0自动;
文本对齐:居中;
填充:0;
保证金:0;
}
div#滚动菜单a{
显示:内联块;
颜色:白色;
文本对齐:居中;
填充:25px 25px;
文字装饰:无;
}
div#滚动菜单a:悬停{
背景色:#777;
}
.主动{
背景色:#777;
}
.向左滑动{
转换:translateX(-300px);
转变:转变0.5s;
}
$(窗口)。滚动(函数(){
var hT=$('#about').offset().top,
hH=$('#about').outerHeight(),
wH=$(窗口).height(),
wS=$(this.scrollTop();
如果(wS>(hT+hH-wH)){
$(“.scroll links container”).addClass(“向左滑动”);
}
});
您将看到,我添加了一些javascript,试图在页面向下滚动到#about部分时让菜单向左滚动,以便底部菜单中的“about”链接滑动到视口的最左侧。但它似乎不起作用
正如我在上一篇文章中所解释的,这就是我试图实现的目标,同时使菜单向后滚动,以便当用户向后滚动到“关于”部分时,“主页”链接位于视口最左侧的原始位置
我还需要用户仍然能够手动滑动菜单左右后,上述行为已经发生
我非常感谢任何人在这方面给予的帮助
非常感谢
Marc请不要忘了在你的问题上贴一个帖子。我们是软件开发人员,不阅读(特别是手册)…嗨,雷内,谢谢你的评论。好的,我已经创建了一个关于codepen的基本示例:您提到的菜单的代码在哪里?我只找到一个
列表,每个列表都有一个.container
和文本内容,还有一个空的JS滚动处理程序。请注意,您不能在SO上发布作业,而希望有人为您构建作业。无论如何,您可以在这里找到()。这也是一个不错的选择。对于您的垂直滚动:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>Horizontal Scrolling Menu</title>
<meta name="description" content="An interactive getting started guide for Brackets.">
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<link rel="stylesheet" href="style.css">
</head>
<body>
<wrapper>
<div class="container heading">
<h1>Horizontal Scrolling Menu</h1>
</div>
<section id="home" class="page-section">
<div class="container">
<h2>Home</h2>
</div>
</section>
<section id="news" class="page-section">
<div class="container">
<h2>News</h2>
</div>
</section>
<section id="contact" class="page-section">
<div class="container">
<h2>Contact</h2>
</div>
</section>
<section id="about" class="page-section">
<div class="container">
<h2>About</h2>
</div>
</section>
<section id="support" class="page-section">
<div class="container">
<h2>Support</h2>
</div>
</section>
<section id="blog" class="page-section">
<div class="container">
<h2>Blog</h2>
</div>
</section>
<section id="tools" class="page-section">
<div class="container">
<h2>Tools</h2>
</div>
</section>
<section id="base" class="page-section">
<div class="container">
<h2>Base</h2>
</div>
</section>
<section id="custom" class="page-section">
<div class="container">
<h2>Custom</h2>
</div>
</section>
<section id="testimonials" class="page-section">
<div class="container">
<h2>Testimonials</h2>
</div>
</section>
<section id="more" class="page-section">
<div class="container">
<h2>More</h2>
</div>
</section>
<div id="scrollmenu">
<div class="scroll-links-container">
<a href="#home" class="link">Home</a>
<a href="#news" class="link">News</a>
<a href="#contact" class="link">Contact</a>
<a href="#about" class="link">About</a>
<a href="#support" class="link">Support</a>
<a href="#blog" class="link">Blog</a>
<a href="#tools" class="link">Tools</a>
<a href="#base" class="link">Base</a>
<a href="#custom" class="link">Custom</a>
<a href="#testimonials" class="link">Testimonials</a>
<a href="#more" class="link">More</a>
</div>
</div>
</wrapper>
body, html {
margin: 0;
padding: 0;
font-family: sans-serif;
font-size: 16px;
background-color: white;
}
html {
scroll-behavior: smooth;
}
wrapper {
display: block;
width: 360px;
margin: 0 auto;
background-color: black;
padding-top: 20px;
}
h1 {
font-family: sans-serif;
font-size: 3.5rem;
color: white;
padding: 0px 20px;
}
h2 {
font-family: sans-serif;
font-size: 2.5rem;
color: white;
}
section {
width: 360px;
background-color: transparent;
}
.container.heading {
padding: 20px 20px 20px 20px;
}
.container {
padding: 200px 40px 200px 40px;
}
div#scrollmenu {
position: fixed;
bottom: 0;
background-color: #333;
overflow: auto;
white-space: nowrap;
width: 360px;
margin: 0 auto;
text-align: center;
padding: 0;
margin: 0;
}
div#scrollmenu a {
display: inline-block;
color: white;
text-align: center;
padding: 25px 25px;
text-decoration: none;
}
div#scrollmenu a:hover {
background-color: #777;
}
.active {
background-color: #777;
}
.slide-about-left {
transform: translateX(-300px);
transition: transform 0.5s;
}
$(window).scroll(function() {
var hT = $('#about').offset().top,
hH = $('#about').outerHeight(),
wH = $(window).height(),
wS = $(this).scrollTop();
if (wS > (hT+hH-wH)){
$(".scroll-links-container").addClass("slide-about-left");
}
});
</body>
</html>