- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个事件日历。我遇到的问题是每次将事件插入到特定日期时,我的其他事件 innerHTML 也会发生变化。
我已经尝试过 event.stopPropagation() 以及 event.stopImmediatePropagation()。
这似乎行不通。
关于我如何使这项工作有什么建议吗?
提前致谢!
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();
});
});
<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>
最佳答案
每次您点击一个日期时,您都会向更改其内部 html 的“提交”操作添加一个监听器,因此您的日期最终会永远监听此“提交”操作。
解决此问题的一种快速方法是在编辑完 innerHtml 后删除监听器,或者使用 {once: true}
将其设置为仅触发一次。
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();
});
});
<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>
关于javascript - NodeList 事件不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51829025/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!