我是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;
答案 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();
}
});