javascript - 请大家看下这段代码的问题
PHP中文网
PHP中文网 2017-04-11 13:02:20
[JavaScript讨论组]

这是一部分代码,

     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不是添加而是本来就存在就会有作用,代码如下:

    
  • sdgd
  • dvsv
  • dscs

请问这是怎么回事?

PHP中文网
PHP中文网

认证0级讲师

全部回复(3)
阿神

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

可以使用事件委托来操作

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

ringa_lee

事件委托~~

伊谢尔伦

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

例如可以
    document.querySelector('#ul').addEventListener('click',function(e){
        if(e.target.tagName=='LI'){this.removeChild(e.target)}
    })
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号