我目前正在研究联系人列表程序。我想让人们能够通过垃圾桶按钮删除列表中的联系人。每个联系人信息都有其自己的按钮,人们可以删除想要删除的任何信息。我的代码通过检查(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>
元素。