gpt4 book ai didi

javascript - Safari ios 中的视差滚动跳动

转载 作者:行者123 更新时间:2023-11-29 10:39:14 26 4
gpt4 key购买 nike

我正在研究视差功能,它在除 safari 之外的所有浏览器上都能正常工作。

我一直在关注 this article看看我可能做错了什么,我想我写错了我的 javascript,因为我直接绑定(bind)到滚动事件。

这可能是一个愚蠢的问题,但我应该如何在不绑定(bind)到滚动事件的情况下开始我的视差滚动事件。我希望图像在用户滚动时以不同的速度朝不同的方向移动。

我的 JS

function onScroll() {

window.requestAnimationFrame(parallax);
function parallax(){
var prlx_effect_1= +(window.pageYOffset *.55).toFixed(2); // .55 for slow | .7 good for fast
var prlx_str_1 = "translate3d(0, "+prlx_effect_1+"px, 0)";
jQ('.prlx-1').css({
"transform":prlx_str_1,
"-ms-transform":prlx_str_1,
"-webkit-transform":prlx_str_1
});

var prlx_effect_2= -(window.pageYOffset *.25 ).toFixed(2); // .2 for slow | .4 good for fast
var prlx_str_2 = "translate3d(0, "+prlx_effect_2+"px, 0)";
jQ('.prlx-2').css({
"transform":prlx_str_2,
"-ms-transform":prlx_str_2,
"-webkit-transform":prlx_str_2
});
window.requestAnimationFrame(parallax);
}
}

window.addEventListener("scroll", onScroll, false);

有什么建议吗?或者是否有其他原因导致视差仅在 safari 上跳动?

最佳答案

首先,从 Underscore 添加这个去抖功能

// debounce is taken from _underscore.js
function debounce(func, wait, immediate) {
var timeout, args, context, timestamp, result;
return function() {
context = this;
args = arguments;
timestamp = new Date();
var later = function() {
var last = (new Date()) - timestamp;
if (last < wait) {
timeout = setTimeout(later, wait - last);
} else {
timeout = null;
if (!immediate) result = func.apply(context, args);
}
};
var callNow = immediate && !timeout;
if (!timeout) {
timeout = setTimeout(later, wait);
}
if (callNow) result = func.apply(context, args);
return result;
};
}

当用户开始滚动时启动 requestAnimationFrame 循环,并在最后一次滚动事件后 100 毫秒使用标志终止它。

var requesting = false;

var killRequesting = debounce(function () {
requesting = false;
}, 100);

function onScroll() {
if (!requesting) {
requesting = true;
requestAnimationFrame(parallax);
}
killRequesting();
}

现在在您的视差函数中,在再次调用自身之前检查标志。

function parallax() {
// your parallax code
if (requesting) {
requestAnimationFrame(parallax);
}
}

其次,您应该始终缓存您的 jQuery 选择器。

var $prlx1 = jQ('.prlx-1');
var $prlx2 = jQ('.prlx-2');
function parallax(){
var prlx_effect_1= +(window.pageYOffset *.55).toFixed(2); // .55 for slow | .7 good for fast
var prlx_str_1 = "translate3d(0, "+prlx_effect_1+"px, 0)";
$prlx1.css({
"transform":prlx_str_1,
"-ms-transform":prlx_str_1,
"-webkit-transform":prlx_str_1
});

var prlx_effect_2= -(window.pageYOffset *.25 ).toFixed(2); // .2 for slow | .4 good for fast
var prlx_str_2 = "translate3d(0, "+prlx_effect_2+"px, 0)";
$prlx2.css({
"transform":prlx_str_2,
"-ms-transform":prlx_str_2,
"-webkit-transform":prlx_str_2
});
if (requesting) {
window.requestAnimationFrame(parallax);
}
}

关于javascript - Safari ios 中的视差滚动跳动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25335829/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com