首页 > 解决方案 > 定位列表中的所有元素,但单击除外

问题描述

我一直在玩 jQuery,但我终于尝试学习干净的 Vanilla JS。

我有一个元素列表:

    <div id="seriesList" class="seriesList rollable">

            <div class="seriesLink" series="7">
                <a href="#carrow-road"><h3 class="name">Carrow Road</h3><p class="location">Norwich</p></a>
            </div>

            <div class="seriesLink" series="6">
                <a href="#white-lane"><h3 class="name">White Heart Lane</h3><p class="location">London</p></a>
            </div>

            <div class="seriesLink" series="5">
                <a href="#parc-des-princes"><h3 class="name">Parc des Princes</h3><p class="location">Paris</p></a>
            </div>
</div

单击其中一个 .seriesLink 后,我正在切换一系列 GSAP 动画。我要实现的第一个目标是使单击的每个元素都消失。即:我点击#carrow-road — #white-lane 和#parc-des-princes 会消失。

我有这个:

document.querySelectorAll(".seriesLink").forEach(item => {
  item.addEventListener('click', event => {

// ForEach.Not ?

    document.getElementById("seriesList").classList.toggle("rollable");
    document.getElementById("home").classList.add("scrollable");
    document.getElementById("rightPanel").classList.remove("scrollable");
    tlOpenSeries.play();
  })
})

Javascript 中的“类”系统让我迷失了方向,因为我似乎无法成功定位我的元素。

我找不到“重现”each.not jquery 提供的方法。任何想法?我是否应该首先向单击的元素添加一个类,然后针对没有此“活动”类的所有元素?有捷径吗?

非常感谢

标签: javascripteach

解决方案


要在 vanilla JS 中实现这一点,您必须遍历元素并检查当前元素是否不是被点击的元素。

演示:

var divs = document.querySelectorAll(".seriesLink");
divs.forEach(item => {
  item.addEventListener('click', event => {

    for(var i = 0; i < divs.length; i++){
      if(event.currentTarget != divs[i]){ // check here
        divs[i].style.display = "none";
      }
    }
    
    //.......
    //.......
  });
});
<div id="seriesList" class="seriesList rollable">
  <div class="seriesLink" series="7">
    <a href="#carrow-road"><h3 class="name">Carrow Road</h3><p class="location">Norwich</p></a>
  </div>

  <div class="seriesLink" series="6">
    <a href="#white-lane"><h3 class="name">White Heart Lane</h3><p class="location">London</p></a>
  </div>

  <div class="seriesLink" series="5">
    <a href="#parc-des-princes"><h3 class="name">Parc des Princes</h3><p class="location">Paris</p></a>
  </div>
</div>


推荐阅读