【问题标题】:Jquery doesn't get element by class [duplicate]Jquery没有按类获取元素[重复]
【发布时间】: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


【解决方案1】:

假设.pizza-menu-left 是动态加载的元素,当 onload 函数运行时它们将不可用,因此您需要在事件处理程序内部定义该变量。

$(function () {
    $(window).on("scroll", () => {
      var pizzaLeft = $(".pizza-menu-left");
      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");
      }
    });
  });

【讨论】:

  • 非常感谢!被一行代码遗漏了 xD 顺便说一句,我读过有关动态加载的内容,但无法真正掌握......你能简要解释一下它背后的逻辑吗? :)
  • load() 方法向某个外部 HTML 文件发出网络请求,然后将该 HTML 放入该元素中。这就是动态加载元素的全部意义。
  • 谢谢 ;) 顺便说一句,很棒的用户名啊哈哈
猜你喜欢
  • 2013-04-30
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2019-01-12
  • 2019-10-02
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多