这是一部分代码,
var ul = document.getElementById('ul-list');
var li = document.getElementsByTagName('li');
//当点击某个li时消除那个li
for(var i = 0;i < li.length;i++){
li[i].onmouseover = function(){
this.onclick = function(){
ul.removeChild(this);
}
}
}
在文本框中输入数字,点右侧按钮会有相应行为,这段代码的意思时点哪个li就会删掉那个,但是并没有反应。
我试验了一下如果li不是添加而是本来就存在就会有作用,代码如下:
<ul id="ul">
<li>sdgd</li>
<li>dvsv</li>
<li>dscs</li>
</ul>
<script type="text/javascript">
var li = document.getElementsByTagName('li');
var ul = document.getElementById('ul');
for(var i = 0;i < li.length;i++){
li[i].onmouseover = function(){
this.onclick = function(){
ul.removeChild(this);
}
}
}
</script>
请问这是怎么回事?
事件委托呀!
为什么默认就有,后添加的没有
因为之前绑定的只是之前的li ,后添加的li 并没有绑定事件
可以使用事件委托来操作
或者,添加后再执行一次for 循环也就是给每个li 再增加一个事件