【发布时间】:2021-11-10 16:35:31
【问题描述】:
希望你做得很好:)
我正在尝试制作滚动动画,并且我在本地 jquery.js 文件中有此代码:
$(() => {
/* Components */
$(".navbar_section").load("../components/navbar.html");
$(".title_section").load("../components/title.html");
$(".welcome_section").load("../components/welcome.html");
$(".trust_section").load("../components/trust.html");
$(".menu_section").load("../components/menu.html");
$(".parallax_section").load("../components/parallax.html");
$(".location_section").load("../components/location.html");
AOS.init();
/* Animations */
$(function () {
var pizzaLeft = $(".pizza-menu-left");
$(window).on("scroll", () => {
var scroll = $(window).scrollTop();
if (scroll >= 1500) {
pizzaLeft.removeClass("roll-out-left");
return pizzaLeft.addClass("roll-in-left");
} else {
pizzaLeft.removeClass("roll-in-left");
return pizzaLeft.addClass("roll-out-left");
}
});
});
});
问题是,.pizza-menu-left 没有被选中,但上面的所有类都选中了。我已经尝试过,live(),on(),但似乎没有任何效果。我知道这都是关于创建 DOM 对象和属性的时间,当然,上面的函数是在设置类属性之前运行的。不过,我不知道如何解决这个问题。
【问题讨论】:
-
您正试图在
.pizza-menu-left元素存在于 DOM 之前检索它。您需要使用on()方法的委托签名或使用相关load()调用的回调,该调用添加它以使其可访问。另请注意,我强烈建议您不要在一个页面中发出这么多load()请求。您实际上是在对自己进行 DDOS。如果您的目标是在多个页面中包含公共内容,请改用服务器端包含;这也将消除对回调的需要。 -
知道了,非常感谢您的建议!也感谢警告和解决方案,我不知道:)
-
别担心,还请注意,您可以删除
return语句并链接addClass/removeClass调用:pizzaLeft.removeClass("roll-out-left").addClass("roll-in-left"); -
干净多了,谢谢! ;)
标签: javascript jquery class animation