首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >NodeList事件不起作用

NodeList事件不起作用
EN

Stack Overflow用户
提问于 2018-08-13 19:07:55
回答 1查看 66关注 0票数 1

我有活动日历。我遇到的问题是,每次将事件插入到特定日期时,我的其他事件innerHTML也会发生变化。

我已经尝试过event.stopPropagation()以及event.stopImmediatePropagation()。

这似乎不管用。

有什么建议可以让我这样做吗?

提前谢谢你!

代码语言:javascript
复制
let dates = document.querySelectorAll(".calendar-date button.date-item");
dates.forEach(function(date){
  date.addEventListener("click",function(e){
    let parentNode = e.currentTarget.parentNode;
    let events = parentNode.querySelector(".calendar-events");
    document.querySelector("#add-modal").classList.add("active");
    let form = document.querySelector("#add-event").addEventListener("submit",function(formEvent){
      formEvent.preventDefault();
      document.querySelector("#add-modal").classList.remove("active");
      let inputValue = this.querySelector("input[name='event-input']");
      events.innerHTML = '<a class="calendar-event bg-success text-light" href="#calendars">'+inputValue.value+'</a>';
    });
    e.stopPropagation();
  });
});
代码语言:javascript
复制
<link href="https://unpkg.com/spectre.css/dist/spectre-icons.min.css" rel="stylesheet"/>
<link href="https://unpkg.com/spectre.css/dist/spectre-exp.min.css" rel="stylesheet"/>
<link href="https://unpkg.com/spectre.css/dist/spectre.min.css" rel="stylesheet"/>

<!DOCTYPE html>
<html lang="en" dir="ltr">
  <head>
    <meta charset="utf-8">
    <title>Spectre Calendar</title>
  </head>
  <body>
    <div class="calendar calendar-lg">
      <!-- calendar navbar structure -->
      <div class="calendar-nav navbar">
        <button class="btn btn-action btn-link btn-lg">
          <i class="icon icon-arrow-left"></i>
        </button>
        <div class="navbar-primary">August 2018</div>
        <button class="btn btn-action btn-link btn-lg">
          <i class="icon icon-arrow-right"></i>
        </button>
      </div>
      <div class="calendar-container">
      <!-- calendar header structure -->
        <div class="calendar-header">
          <div class="calendar-date">SUN</div>
          <div class="calendar-date">MON</div>
          <div class="calendar-date">TUE</div>
          <div class="calendar-date">WED</div>
          <div class="calendar-date">THU</div>
          <div class="calendar-date">FRI</div>
          <div class="calendar-date">SAT</div>
        </div>

        <div class="calendar-body">
          <!-- calendar date with events -->

          <!-- calendar prev month days -->
          <div class="calendar-date prev-month">
            <button class="date-item">29</button>
          </div>

          <div class="calendar-date prev-month">
            <button class="date-item">30</button>
          </div>

          <div class="calendar-date prev-month">
            <button class="date-item">31</button>
          </div>

          <!-- calendar current month days -->
          <div class="calendar-date">
            <button class="date-item">1</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">2</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">3</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">4</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">5</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">6</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">7</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">8</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item date-today">9</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">10</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">11</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">12</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">13</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">14</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">15</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item disabled">16</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">17</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">18</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">19</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">20</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">21</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">22</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">23</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">24</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">25</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">26</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">27</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">28</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">29</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">30</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">31</button>
            <div class="calendar-events"></div>
          </div>

          <!-- calendar next month -->
          <div class="calendar-date next-month">
            <button class="date-item">1</button>
            <div class="calendar-events"></div>
          </div>

        </div>
      </div>
    </div>

    <!--ADD EVENT MODAL-->
    <div class="modal" id="add-modal">
      <a href="#close" class="modal-overlay" aria-label="Close"></a>
      <div class="modal-container">
        <div class="modal-header">
          <a href="#close" class="btn btn-clear float-right" aria-label="Close"></a>
          <div class="modal-title h5">Add Event</div>
        </div>
        <form id="add-event">
          <div class="modal-body">
            <div class="content">
              <div class="form-group">
                <input class="form-input" type="text" name="event-input" placeholder="Type text here...">
              </div>
            </div>
          </div>
          <div class="modal-footer">
            <button type="submit" class="btn btn-success">Add</button>
          </div>
        </form>
      </div>
    </div>
  </body>
</html>

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-13 19:34:48

每次单击某个日期时,都会向"Submit“操作添加一个侦听器,该操作将更改其内部html,因此您的日期最终将永远侦听此"submit”操作。

解决这个问题的一个快速方法是在编辑完innerHtml之后删除侦听器,或者使用{once: true}将其设置为只触发一次。

代码语言:javascript
复制
let dates = document.querySelectorAll(".calendar-date button.date-item");
dates.forEach(function(date){
  date.addEventListener("click",function(e){
    let parentNode = e.currentTarget.parentNode;
    let events = parentNode.querySelector(".calendar-events");
    document.querySelector("#add-modal").classList.add("active");
    let form = document.querySelector("#add-event").addEventListener("submit",function(formEvent){
      formEvent.preventDefault();
      document.querySelector("#add-modal").classList.remove("active");
      let inputValue = this.querySelector("input[name='event-input']");
      events.innerHTML = '<a class="calendar-event bg-success text-light" href="#calendars">'+inputValue.value+'</a>';
    }, {once: true});
    e.stopPropagation();
  });
});
代码语言:javascript
复制
<link href="https://unpkg.com/spectre.css/dist/spectre-icons.min.css" rel="stylesheet"/>
<link href="https://unpkg.com/spectre.css/dist/spectre-exp.min.css" rel="stylesheet"/>
<link href="https://unpkg.com/spectre.css/dist/spectre.min.css" rel="stylesheet"/>

<!DOCTYPE html>
<html lang="en" dir="ltr">
  <head>
    <meta charset="utf-8">
    <title>Spectre Calendar</title>
  </head>
  <body>
    <div class="calendar calendar-lg">
      <!-- calendar navbar structure -->
      <div class="calendar-nav navbar">
        <button class="btn btn-action btn-link btn-lg">
          <i class="icon icon-arrow-left"></i>
        </button>
        <div class="navbar-primary">August 2018</div>
        <button class="btn btn-action btn-link btn-lg">
          <i class="icon icon-arrow-right"></i>
        </button>
      </div>
      <div class="calendar-container">
      <!-- calendar header structure -->
        <div class="calendar-header">
          <div class="calendar-date">SUN</div>
          <div class="calendar-date">MON</div>
          <div class="calendar-date">TUE</div>
          <div class="calendar-date">WED</div>
          <div class="calendar-date">THU</div>
          <div class="calendar-date">FRI</div>
          <div class="calendar-date">SAT</div>
        </div>

        <div class="calendar-body">
          <!-- calendar date with events -->

          <!-- calendar prev month days -->
          <div class="calendar-date prev-month">
            <button class="date-item">29</button>
          </div>

          <div class="calendar-date prev-month">
            <button class="date-item">30</button>
          </div>

          <div class="calendar-date prev-month">
            <button class="date-item">31</button>
          </div>

          <!-- calendar current month days -->
          <div class="calendar-date">
            <button class="date-item">1</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">2</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">3</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">4</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">5</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">6</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">7</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">8</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item date-today">9</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">10</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">11</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">12</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">13</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">14</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">15</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item disabled">16</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">17</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">18</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">19</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">20</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">21</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">22</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">23</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">24</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">25</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">26</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">27</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">28</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">29</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">30</button>
            <div class="calendar-events"></div>
          </div>

          <div class="calendar-date">
            <button class="date-item">31</button>
            <div class="calendar-events"></div>
          </div>

          <!-- calendar next month -->
          <div class="calendar-date next-month">
            <button class="date-item">1</button>
            <div class="calendar-events"></div>
          </div>

        </div>
      </div>
    </div>

    <!--ADD EVENT MODAL-->
    <div class="modal" id="add-modal">
      <a href="#close" class="modal-overlay" aria-label="Close"></a>
      <div class="modal-container">
        <div class="modal-header">
          <a href="#close" class="btn btn-clear float-right" aria-label="Close"></a>
          <div class="modal-title h5">Add Event</div>
        </div>
        <form id="add-event">
          <div class="modal-body">
            <div class="content">
              <div class="form-group">
                <input class="form-input" type="text" name="event-input" placeholder="Type text here...">
              </div>
            </div>
          </div>
          <div class="modal-footer">
            <button type="submit" class="btn btn-success">Add</button>
          </div>
        </form>
      </div>
    </div>
  </body>
</html>

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51829025

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档