在ul javascript

时间:2016-03-16 12:29:35

标签: javascript appendchild removechild

我是JavaScript的新手,还在学习各种各样的东西。现在我一直坚持在列表中添加和删除li元素。我使用jQuery做了很好的练习,但现在对同一任务的纯JS版本有困难。

主要思想是通过单击按钮添加新的li元素,然后单击旁边的X按钮删除元素。我尝试过使用这个'和Stackoverflow上类似问题中提到的其他建议,但没有任何对我有用。请你帮我指导我做错了什么?

P.S。添加功能似乎在片段中工作,但控制台日志错误:无法读取属性' addeventlistener' null。



//declaring the variables
var btn = document.getElementsByClassName('btn');
var list = document.getElementById('list');
var add = document.getElementById('add');

//adding a new element to the list
add.addEventListener('click', function(){
  var newElement = document.createElement('LI');
  list.appendChild(newElement);
  newElement.innerHTML= "I am a new element<button class='btn'>X</button>";
});

//removing the clicked element
btn.addEventListener('click', function(){
  list.parentNode.removeChild(this);
});
&#13;
ul li {
  decoration: none;
  display: block;
  margin-top: 1em;
  text-align: center;
  font-family:  'Avant Garde', Avantgarde, 'Century Gothic', CenturyGothic, AppleGothic, sans-serif;
  font-size: 18px;
}

#add {
  background-color: black;
  color: white;
  border: none;
  width: 280px;
  font-color: white;
  border-radius: 8px;
  font-size: 16px;
  padding: 15px;
  outline: none;
  text-align: center;
  margin: 20px auto;
  display: block;
}

#add:hover {
  background-color: #28364d;
  color: white;
  border: none;
  outline: none;
}

#add:active {
  position: relative;
  bottom: 2px;
}

.btn{
  margin-left: 10px;
  border-radius: 10px;
  background-color: #000;
  color: white;
  border: none;
  outline: none;
  font-size: 14px;
  font-family: sans-serif;
}

.btn:active {
position: relative;
bottom: 2px;
}
&#13;
<div>
      <ul id="list">
        <li class="element">I am a new element<button class="btn">X</button></li>
        <li class="element">I am a new element<button class="btn">X</button></li>
        <li class="element">I am a new element<button class="btn">X</button></li>
        <li class="element">I am a new element<button class="btn">X</button></li>
        <li class="element">I am a new element<button class="btn">X</button></li>
      </ul>

    <button id="add">Add an element to the list</button>
</div>
&#13;
&#13;
&#13;

3 个答案:

答案 0 :(得分:2)

在您的情况下,btn是元素的节点列表,而不是元素,因此您无法将事件附加到数组。你需要遍历它们:

for(i=0; i < btn.length; i++) {
   btn[i].addEventListener('click', function(){
      list.parentNode.removeChild(this);
   });
}

答案 1 :(得分:1)

这将返回非实时集合:

var btn = document.getElementsByClassName('btn');

这意味着它只包含方法调用点存在的对象。您需要在创建新getElementsByClassName()元素后调用li,并在 invidual 按钮上附加EventListeners。请记住不要在按钮上放置两次EventListener。

更好的解决方案

更好的是:不要使用getElementsByClassName(),只需将事件处理程序直接附加到您创建新按钮的函数中。这样,您就不必担心预先存在的事件处理程序:

add.addEventListener('click', function(){
    var newElement = document.createElement('LI');
    list.appendChild(newElement);
    newElement.innerHTML= "I am a new element<button class='btn'>X</button>";
    newElement.addEventListener('click', function () {
        this.parentNode.removeChild(this);
    });
});

答案 2 :(得分:1)

我也在学习,作为一个新人,这是一个很好的小挑战。感谢rlemon通过该文章链接指引我们正确的方向。我在这里学到的东西。

如果您对我到达的内容感兴趣: https://jsfiddle.net/nyxhj0tg/1/

JS:

var list = document.getElementById('list');
var add = document.getElementById('add');

//adding a new element to the list
add.addEventListener('click', function(){
  var newElement = document.createElement('LI');
  list.appendChild(newElement);
  newElement.innerHTML= "I am a new element<button class='btn'>X</button>";

});

list.addEventListener('click', function(e){
  if(e.target && e.target.nodeName == "BUTTON") {
        console.log("Button ", e, " was clicked!");
    e.target.parentNode.remove();
    }
});