滚动触发的动画极度延迟
scroll triggered animation extremely delayed
使用jQuery,我想做一个类似于this Wordpress plugin的导航栏:导航栏在页面加载时hidden/offscreen,当某个特定的时候向下滑动到固定位置到达滚动位置,并在用户向上滚动到顶部时滑回其屏幕外位置。
我设法做到了,但是时间完全错误:滚动后可能需要几秒钟才能出现菜单栏。向上滚动时更糟:起初我认为它根本不起作用,但有时 15 秒甚至更长时间后,它最终又向上移动。
这是我的代码:
$(window).scroll(function() {
var scrollposition = $(window).scrollTop();
if (scrollposition > 100) {
$("#main_navigation").animate({
top: "0px"
}, 600);
};
if (scrollposition < 100) {
$("#main_navigation").animate({
top: "-82px"
}, 400);
};
});
html,
body {
margin: 0;
height: 100%;
}
.content {
height: 200%;
background: #fda;
padding: 5em 3em;
}
nav#main_navigation {
position: fixed;
z-index: 1;
top: -82px;
width: 100%;
background: #fff;
height: 54px;
border-bottom: 1px solid #eee;
}
.logo {
display: inline-block;
position: relative;
top: 50%;
left: 2em;
margin: 0;
width: 36px;
transform: translateY(-50%);
}
nav#main_navigation ul {
position: relative;
top: 50%;
margin: 0;
transform: translateY(-50%);
display: inline-block;
list-style: none;
float: right;
margin-right: 0.8em;
}
nav#main_navigation li {
display: inline-block;
margin-right: 1.2em;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<nav id="main_navigation">
<div class="logo">(logo)</div>
<ul>
<li><a href="#">Welcome</a></li>
<li><a href="#">About</a></li>
<li><a href="#">Contact</a></li>
</ul>
</nav>
<div class="content">
<p>This is the content. Scroll down at least 100px to make the navbar appear. This should take 0.6 seconds, but takes much longer.</p>
<p>Then scroll back up to make the navbar disappear again. This should only take 0.4 seconds...</p>
</div>
我想这可能与必须处理的滚动事件太多有关,但我不知道如何避免或过滤它。还是另有原因?
我想通了:有很多个滚动事件,并且每个滚动事件都会触发一个动画,这对于浏览器来说显然太多了。需要很长时间才能处理完所有这些并最终执行动画,从而导致长时间延迟。
所以我寻找一种方法让向下和向上滑动动画仅在触发另一个动画之前一次触发。我使用了一个变量(status_1
),其默认值为"closed"。当滚动值超过 100 时,仅当 status_1
为 "closed" 时才会触发第一个(向下滑动)动画。但是一旦触发,status_1
设置为"open",所以只要滚动值在100以上就不会再次触发。与第二个if条件和动画相同:
var status_1 = "closed";
$(window).scroll(function() {
var scrollposition = $(this).scrollTop();
if ((scrollposition > 100) && (status_1 == "closed")) {
$('#main_navigation').animate({
top: '0px'
}, 600);
status_1 = "open";
};
if ((scrollposition < 100) && (status_1 == "open")) {
$('#main_navigation').animate({
top: '-82px'
}, 400);
status_1 = "closed";
};
});
html,
body {
margin: 0;
height: 100%;
}
.content {
height: 200%;
background: #fda;
padding: 5em 3em;
}
nav#main_navigation {
position: fixed;
z-index: 1;
top: -82px;
width: 100%;
background: #fff;
height: 54px;
border-bottom: 1px solid #eee;
}
.logo {
display: inline-block;
position: relative;
top: 50%;
left: 2em;
margin: 0;
width: 36px;
transform: translateY(-50%);
}
nav#main_navigation ul {
position: relative;
top: 50%;
margin: 0;
transform: translateY(-50%);
display: inline-block;
list-style: none;
float: right;
margin-right: 0.8em;
}
nav#main_navigation li {
display: inline-block;
margin-right: 1.2em;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<nav id="main_navigation">
<div class="logo">(logo)</div>
<ul>
<li><a href="#">Welcome</a></li>
<li><a href="#">About</a></li>
<li><a href="#">Contact</a></li>
</ul>
</nav>
<div class="content">
<p>This is the content. Scroll down at least 100px to make the navbar appear. This should take 0.6 seconds.</p>
<p>Then scroll back up to make the navbar disappear again. This should only take 0.4 seconds...</p>
</div>
使用jQuery,我想做一个类似于this Wordpress plugin的导航栏:导航栏在页面加载时hidden/offscreen,当某个特定的时候向下滑动到固定位置到达滚动位置,并在用户向上滚动到顶部时滑回其屏幕外位置。
我设法做到了,但是时间完全错误:滚动后可能需要几秒钟才能出现菜单栏。向上滚动时更糟:起初我认为它根本不起作用,但有时 15 秒甚至更长时间后,它最终又向上移动。
这是我的代码:
$(window).scroll(function() {
var scrollposition = $(window).scrollTop();
if (scrollposition > 100) {
$("#main_navigation").animate({
top: "0px"
}, 600);
};
if (scrollposition < 100) {
$("#main_navigation").animate({
top: "-82px"
}, 400);
};
});
html,
body {
margin: 0;
height: 100%;
}
.content {
height: 200%;
background: #fda;
padding: 5em 3em;
}
nav#main_navigation {
position: fixed;
z-index: 1;
top: -82px;
width: 100%;
background: #fff;
height: 54px;
border-bottom: 1px solid #eee;
}
.logo {
display: inline-block;
position: relative;
top: 50%;
left: 2em;
margin: 0;
width: 36px;
transform: translateY(-50%);
}
nav#main_navigation ul {
position: relative;
top: 50%;
margin: 0;
transform: translateY(-50%);
display: inline-block;
list-style: none;
float: right;
margin-right: 0.8em;
}
nav#main_navigation li {
display: inline-block;
margin-right: 1.2em;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<nav id="main_navigation">
<div class="logo">(logo)</div>
<ul>
<li><a href="#">Welcome</a></li>
<li><a href="#">About</a></li>
<li><a href="#">Contact</a></li>
</ul>
</nav>
<div class="content">
<p>This is the content. Scroll down at least 100px to make the navbar appear. This should take 0.6 seconds, but takes much longer.</p>
<p>Then scroll back up to make the navbar disappear again. This should only take 0.4 seconds...</p>
</div>
我想这可能与必须处理的滚动事件太多有关,但我不知道如何避免或过滤它。还是另有原因?
我想通了:有很多个滚动事件,并且每个滚动事件都会触发一个动画,这对于浏览器来说显然太多了。需要很长时间才能处理完所有这些并最终执行动画,从而导致长时间延迟。
所以我寻找一种方法让向下和向上滑动动画仅在触发另一个动画之前一次触发。我使用了一个变量(status_1
),其默认值为"closed"。当滚动值超过 100 时,仅当 status_1
为 "closed" 时才会触发第一个(向下滑动)动画。但是一旦触发,status_1
设置为"open",所以只要滚动值在100以上就不会再次触发。与第二个if条件和动画相同:
var status_1 = "closed";
$(window).scroll(function() {
var scrollposition = $(this).scrollTop();
if ((scrollposition > 100) && (status_1 == "closed")) {
$('#main_navigation').animate({
top: '0px'
}, 600);
status_1 = "open";
};
if ((scrollposition < 100) && (status_1 == "open")) {
$('#main_navigation').animate({
top: '-82px'
}, 400);
status_1 = "closed";
};
});
html,
body {
margin: 0;
height: 100%;
}
.content {
height: 200%;
background: #fda;
padding: 5em 3em;
}
nav#main_navigation {
position: fixed;
z-index: 1;
top: -82px;
width: 100%;
background: #fff;
height: 54px;
border-bottom: 1px solid #eee;
}
.logo {
display: inline-block;
position: relative;
top: 50%;
left: 2em;
margin: 0;
width: 36px;
transform: translateY(-50%);
}
nav#main_navigation ul {
position: relative;
top: 50%;
margin: 0;
transform: translateY(-50%);
display: inline-block;
list-style: none;
float: right;
margin-right: 0.8em;
}
nav#main_navigation li {
display: inline-block;
margin-right: 1.2em;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<nav id="main_navigation">
<div class="logo">(logo)</div>
<ul>
<li><a href="#">Welcome</a></li>
<li><a href="#">About</a></li>
<li><a href="#">Contact</a></li>
</ul>
</nav>
<div class="content">
<p>This is the content. Scroll down at least 100px to make the navbar appear. This should take 0.6 seconds.</p>
<p>Then scroll back up to make the navbar disappear again. This should only take 0.4 seconds...</p>
</div>