gpt4 book ai didi

javascript - 如何从 querySelectorAll 获取所有元素并与 addEventListener 一起使用

转载 作者:搜寻专家 更新时间:2023-11-01 05:27:59 24 4
gpt4 key购买 nike

我有一个障碍。当我点击加号时,创建了 4 个子 block 。当我点击任何子 block 加号按钮(rooms-guests-plus class)时,我必须添加,它们从 0 增加到 5 当点击减号按钮时(rooms-guests-minus 类)以同样的方式减少。

const room = document.querySelector('.room-guests-count');
const form = document.querySelector('.form-open');
const adultsChildren = document.querySelector('.adults-children');
const adultsChildrenWrapper = document.querySelector('.adults-children-wrapper');

const toggleRoom = () => {
const addRoomButton = document.querySelector('#add-room');
const removeRoomButton = document.querySelector('#remove-room');
const countRoom = document.querySelector('.form-text');

const addSection = () => {
const wrapper = document.createElement("div");
wrapper.className = "adults-children-wrapper";
wrapper.innerHTML = adultsChildrenWrapper.innerHTML;
adultsChildren.appendChild(wrapper).querySelector(".room-count").innerText = countRoom.value;

}
const removeSection = () => {
adultsChildren.lastChild.remove();
}

addRoomButton.onclick = () => {
if(countRoom.value == 4) return;
countRoom.value++;
addSection();
}
removeRoomButton.onclick = () => {
if(countRoom.value == 1) return;
countRoom.value--;
removeSection();
}
}
toggleRoom();
body {
background:#000;
}
/*ROOM GUESTS COUNT*/
.room-guests-count {
width: 32.2%;
cursor: pointer;
margin-right: 4%;
background: #fff;
float: left;
height: 66px;
margin-right: 149px;
}
.form-open {
display: block;
position: absolute;
z-index: -1;
top: 85px;
background-color: #fff;
height: auto;
width: 348px;
}

.form-open:after {
content: '';
position: absolute;
width: 0;
height: 0;
border-bottom: 10px solid #fff;
border-left: 10px solid transparent;
border-right: 10px solid transparent;
right: 300px;
top: -10px;
}
.room-guests-content {
padding-top: 23px;
padding-left: 15px;
}
.click_hidden_text {
position: absolute;
z-index: 1;
left: 163px;
top: 56px;
opacity: 0.8;
}
.form-search {
padding: 0;
margin: 10px 10px 5px 10px;

}
.form-item {
padding: 10px 5px;
clear: both;
height: 14px;
}
.edit-rooms {
font-weight: normal;
font-size: 13px;
float: left;
color: #000;
margin-right: 5px;
}
.rooms-guests-plus, #add-room {
float: right;
color: #fff;
background:#ccc;
width: 24px;
height: 24px;
text-align: center;
line-height: 24px;
top: -6px;
position: relative;
font-size: 18px;
cursor: pointer;
}
.form-text {
text-align: center;
width: 6%;
width: 20px !important;
text-decoration: center;
float: right;
border:0;
padding: 0;
height: auto;
outline: 0;
vertical-align: middle;
}
.textfield label {
margin-right: 2.5px;
display: inline;
font-size: 13px;
}
.children-1 label {
display: inline;
font-size: 13px;
}
.rooms-guests-minus, #remove-room {
float: right;
color: #fff;
background:#e7e7e7;
width: 24px;
height: 24px;
text-align: center;
line-height: 24px;
top: -6px;
position: relative;
font-size: 18px;
cursor:auto;
}
.adults-children {
clear: both;
}
.rooms-id {
line-height: 40px;
float: left;
padding:5px 0 0 15px;
color: #000;
}
.already-min {
float: right;
margin: -16px 0px 2px 6px;
padding: 0;
background: #fff;
}
.already-min-search {
float: right;
margin: 5px 10px 5px 2px;
}
.adults-children-wrapper {
clear: both;
}
.children-1 {
padding: 10px 5px;
clear: both;
height: 14px;
}
.edit-children {
font-weight: normal;
font-size: 13px;
float: left;
color: #000;
margin-right: 5px;
}
.textfield {
clear: both;
height: 14px;
margin: 0;
position: relative;
margin-top: 32px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="room-guests-count">
<div class="room-guests-content">
Adult
<span>2</span>
, Child
<span>0</span>
</div>
</div>
<div class="form-open">
<div class="form-search">
<div class="form-item">
<label class="edit-rooms">Amount of number</label>
<div id="add-room">+</div>
<input class="form-text" value="1">
<div id="remove-room">-</div>
</div>
</div>
<div class="adults-children">
<div class="adults-children-wrapper">
<div class="rooms-id">Number <span class="room-count">1</span>:</div>
<div class="already-min-search">
<div class="children-1">
<label for="edit-children">Child</label>
<div class="rooms-guests-plus">+</div>
<input type="text" value="0" class="form-text">
<div class="rooms-guests-minus">-</div>
</div>
</div>
<div class="already-min">
<div class="textfield">
<label for="edit">Adult</label>
<div class="rooms-guests-plus">+</div>
<input type="text" value="0" class="form-text">
<div class="rooms-guests-minus">-</div>
</div>
</div>
</div>
</div>
</div>

我在 addSection 函数 中编写了 if block ,循环遍历所有元素(类 .rooms-child- plus) 它有效,但循环显示错误 Can not read property 'addEventListener' of undefined

if (adultsChildren.appendChild(wrapper)) {
for(let i = 0;i < 4;i++){
var roomsChildPlus = document.querySelectorAll(".rooms-child-plus");
roomsChildPlus[i].addEventListener("click", function(){
alert("hi");
})
}
}

问题是为什么会输出这样的错误,而且我在正确的路径上?以及如何使用 querySelectorAll 获取所有元素,然后以同样的方式将 addEventListener 用作数组

最佳答案

您应该遍历 roomsChildPlus 而不是硬编码长度 4。

var roomsChildPlus = document.querySelectorAll(".rooms-child-plus");

for(let j=0; j<roomsChildPlus.length; j++){
roomsChildPlus[j].addEventListener("click", function(){
alert("hi");
});
}

关于javascript - 如何从 querySelectorAll 获取所有元素并与 addEventListener 一起使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48170576/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com