javascript - 如何使列表项的删除按钮起作用
问题描述
我目前正在开发一个联系人列表程序。我想让人们能够通过垃圾桶按钮删除列表中的联系人。每个联系信息都有自己的按钮,人们可以删除他们想要删除的任何内容。我的代码通过检查(chrome)没有显示任何错误,但代码不起作用。
var demo = document.getElementById("demo");
function addName() {
var fname = document.getElementById("fname").value;
var entry = document.createElement("li");
var img = document.createElement("img");
img.src = "img/talkbox.png";
$(img).addClass("talkbox");
var deleteBtn = document.createElement("img");
deleteBtn.src = "img/delete.png";
$(deleteBtn).addClass("deleteBtn");
entry.appendChild(img);
entry.appendChild(document.createTextNode(fname));
entry.appendChild(deleteBtn);
demo.appendChild(entry);
document.getElementById('fname').value = "";
};
const trashCan = document.getElementById("trashcan");
trashCan.addEventListener('click', removeEvent);
function removeEvent(e) {
const list = document.getElementById("demo");
if (e.target.classList.contains('deleteBtn')) {
list.removeChild(e.target.parentElement);
list.removeChild(list);
};
};
<div>
<ul id="contactlist" class=ppl>
<li id="pplli">
<img id="wetalk" class="talkbox" src="img/talkbox.png">
<p class="contactname">Aiden<img id="trashcan" class="deleteBtn" src="img/delete.png"></p>
</li>
<ol id="demo">
</ol>
<br>
<a href="#addform" class="pplbtn" id="add"><img id="plus" src="img/plus.png"></a>
</ul>
</div>
解决方案
const trashCan = document.getElementById("trashcan");
如果您有一个项目列表并且您正在使用此代码,那么这将不起作用,因为 ID 在文档中必须是唯一的。如果您创建多个元素并为它们提供相同的 ID,当您尝试通过其 ID 获取元素时,浏览器将不知道您在谈论哪一个。
另外,您应该使用适当的 HTML 元素来构建文档,否则会导致可访问性问题。图像不是按钮。考虑改用该<button>
元素。
推荐阅读
- python - 检测带有标记的 PDF 页面?
- flutter - Flutter: Package can't load a string resource using rootBundle.loadString - asset indenting correct
- excel - INDEX MATCH 唯一值的 Excel TEXTJOIN
- apache-kafka - 如何使用 Kafka REST 代理处理背压
- c++ - 在不锁定 Mutex 的情况下读取受 Mutex 保护的共享数据
- c# - 通过list c#同时检查多个字符串
- python - 如何使用多线程使此代码更快
- typescript - Typescript:为类型别名创建扩展方法
- python - 在循环中将值添加到行并在数据框中连接
- java - spring-data-jpa 多对多 findByID