如何使列表项的删除按钮起作用

问题描述 投票:0回答:1

我目前正在研究联系人列表程序。我想让人们能够通过垃圾桶按钮删除列表中的联系人。每个联系人信息都有其自己的按钮,人们可以删除想要删除的任何信息。我的代码通过检查(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>
javascript list button removechild
1个回答
0
投票
const trashCan = document.getElementById("trashcan");

如果您有项目列表,并且正在使用此代码,则此方法将无法正常工作,因为ID在文档中必须唯一。如果创建多个元素并赋予它们相同的ID,则当您尝试通过其ID获取元素时,浏览器将不会知道您在谈论哪个元素。

另外,您应该使用适当的HTML元素来构造文档,否则会导致可访问性问题。图像不是按钮。考虑改用<button>元素。

© www.soinside.com 2019 - 2024. All rights reserved.