gpt4 book ai didi

javascript - 从父元素中删除子元素已成功,但引发错误

转载 作者:行者123 更新时间:2023-12-03 04:17:59 25 4
gpt4 key购买 nike

考虑我制作的这个例子,其特点是将每个输入的输入文本转换为标签。

示例代码

 
var query = document.querySelector.bind(document);

query('#textfield').addEventListener('keyup', addTag);

function addTag(e) {
var evt = e.target;

if(evt.value) {
var items = evt.value.split(',');

if(items.length <= 10) {
evt.nextElementSibling.innerHTML = null;

for(var i = 0; i < items.length; i++) {
if(items[i].length > 0) {
var label = document.createElement('label'),
span = document.createElement('span');

label.className = 'tag';
label.textContent = items[i];

span.className = 'remove';
span.title = 'Remove';
span.textContent = 'x';

label.insertAdjacentElement('beforeend', span);

evt.nextElementSibling.appendChild(label);

for(var l = 0; l < evt.nextElementSibling.children.length; l++) {
evt.nextElementSibling.children[l].firstElementChild.addEventListener('click', function() {
var $currentElement = this;

$currentElement.parentNode.parentNode.removeChild($currentElement.parentNode);
})
}
}
}
}
} else {
evt.nextElementSibling.innerHTML = null;
}
}
    section {
width: 100%;
height: 100vh;

background: orange;

display: flex;
align-items: center;
justify-content: center;
}

.container {
width: 50%;
}

input[name] {
width: 100%;
border: none;
border-radius: 1rem 1rem 0 0;
font: 1rem 'Arial', sans-serif;
padding: 1rem;
background: #272727;
color: orange;
box-shadow: inset 0 0 5px 0 orange;
}

input[name]::placeholder {
font: 0.9rem 'Arial', sans-serif;
opacity: 0.9;
}

.tags {
width: 100%;
height: 250px;
padding: 1rem;
background: #dfdfdf;
border-radius: 0 0 1rem 1rem;
box-shadow: 0 5px 25px 0px rgba(0,0,0,0.4);
position: relative;
}

.tags > label {
width: auto;
display: inline-block;
background: #272727;
color: orange;
font: 1.1rem 'Arial', sans-serif;
padding: 0.4rem 0.6rem;
border-radius: .2rem;
margin: 5px;
}

.tags > label > span {
font-size: 0.7rem;
margin-left: 10px;
position: relative;
bottom: 2px;
color: #ff4d4d;
cursor: pointer;
}
 <section id="tags-input">
<div class="container">
<input type="text" name="items" id="textfield" placeholder="Enter any item, separated by comma(','). Maximum of 10" autofocus>
<div class="tags"></div>
</div>
</section>

它是成功的,但是当我在删除标签时打开控制台时,我注意到它在我删除的每个标签上抛出一个错误,上面写着:

Uncaught TypeError: Cannot read property 'removeChild' of null

为什么会发生这种情况?我相信使用parentNode两次没有什么问题。是因为我在事件监听器中有另一个事件监听器吗?因为如果我在外部创建另一个事件监听器,它不会通过添加和删除标签进行实时更新,因为关闭按钮位于每个标签内部

最佳答案

这是因为您向“span.remove”添加点击事件超过 1 次。尽量不要每次都将该事件添加到所有“span.remove”中。

关于javascript - 从父元素中删除子元素已成功,但引发错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44065282/

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