请大家看下这段代码的问题

这是一部分代码,

     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>

请问这是怎么回事?

阅读 2k
3 个回答

事件委托呀!
为什么默认就有,后添加的没有
因为之前绑定的只是之前的li ,后添加的li 并没有绑定事件

可以使用事件委托来操作

或者,添加后再执行一次for 循环也就是给每个li 再增加一个事件

因为新增加的li没有添加到事件啊

例如可以
    document.querySelector('#ul').addEventListener('click',function(e){
        if(e.target.tagName=='LI'){this.removeChild(e.target)}
    })
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题