有时我可以访问我的html标签的id有时不能

gab6jxml  于 2023-02-06  发布在  其他
关注(0)|答案(1)|浏览(106)

enter image description here我想访问链接到我的图标的data-id,以便使用它们来操作与这些id相关的部分
但问题是,当我按下图标时,有时会出现未定义的情况,有时会工作,我不知道为什么
请给我解释一下我做错了什么。

<body class="main-content">
    <header class="section sec1 header active" id="home"></header>
    <main>
      <section class="section sec2 about" id="about"></section>
      <section class="section sec3 portfolio" id="portfolio"></section>
      <section class="section sec4 contact" id="contact"></section>
    </main>
    <div class="controls">
      <div class="control control-1 active-btn" data-id="home">
        <i class="fa-solid fa-house"></i>
      </div>
      <div class="control control-2" data-id="about">
        <i class="fa-solid fa-user"></i>
      </div>
      <div class="control control-3" data-id="portfolio">
        <i class="fa-solid fa-briefcase"></i>
      </div>
      <div class="control control-4" data-id="contact">
        <i class="fa-solid fa-address-book"></i>
      </div>
    </div>
  </body>
</html>

这是JavaScript

let active = document.querySelectorAll(".control");
let allsections = document.querySelectorAll(".main-content");
let section = document.querySelectorAll(".section");
function makingActive() {
  active.forEach((e) => {
    e.addEventListener("click", () => {
      let active_1 = document.querySelectorAll(".active-btn");
      active_1.forEach((e) => {
        e.classList.remove("active-btn");
      });
      e.classList.add("active-btn");
    });
  });
  allsections.forEach((e) => {
    e.addEventListener("click", (e) => {
      const id = e.target.dataset.id;
      console.log(id);
      section.forEach((sec) => {
        sec.classList.remove("active");
      });
      const secActive = document.getElementById(id);
      secActive.classList.add("active");
    });
  });
}

makingActive();
iszxjhcz

iszxjhcz1#

我觉得你想要这样的东西:

const allSections = Array.from(document.querySelectorAll('.section'))
const allControls = Array.from(document.querySelectorAll('.control'))

allSections.forEach((e) => {
  e.addEventListener('click', (e) => {
    const id = e.target.dataset.id
    const secActive = document.getElementById(id)
    
    console.clear()
    console.log('id:', id)
    
    allControls.forEach((sec) => {
      sec.classList.remove('active')
    })
    secActive.classList.add('active')
  })
})
.section {
  cursor: pointer;
}

.active {
  color: red;
}

.controls {
  margin: 20px 0 0;
  font-size: 20px;
}
<header class="section sec1 header" data-id="home">Home</header>
<main>
  <section class="section sec2 about" data-id="about">About</section>
  <section class="section sec3 portfolio" data-id="portfolio">Portfolio</section>
  <section class="section sec4 contact" data-id="contact">Contact</section>
</main>
<div class="controls">
  <div class="control control-1 active-btn active" id="home">
    <i class="fa-solid fa-house"></i> -> home
  </div>
  <div class="control control-2" id="about">
    <i class="fa-solid fa-user"></i> -> about
  </div>
  <div class="control control-3" id="portfolio">
    <i class="fa-solid fa-briefcase"></i> -> portfolio
  </div>
  <div class="control control-4" id="contact">
    <i class="fa-solid fa-address-book"></i> -> contact
  </div>
</div>

相关问题