如何将eventListener添加到未来的dom元素?

 戴乐季206 发布于 2023-02-13 13:45

文件partial.html看起来像这样:

Partial.html动态地包含在页面上,使用XMLHttpRequest:

var oReq = new XMLHttpRequest();
oReq.open('get', 'partial.html', true);
oReq.send();
oReq.onload = function(){
        document.querySelector('#pageArea').innerHTML = this.response;
    }
}

如何添加一个将应用于将来exisiting的事件侦听器,#test 而不是在内容加载并插入后执行#pageArea

(请不要使用jQuery解决方案!)

1 个回答
  • 点击 气泡这样的事件,所以你将事件处理程序附加到最近的非动态父级,并在事件处理程序内部通过查看它是否是事件的目标来检查是否是被单击的按钮:

    var parent = document.getElementById('pageArea');
    
    if (parent.addEventListener) {
        parent.addEventListener('click', handler, false);
    }else if (parent.attachEvent) {
        parent.attachEvent('onclick', handler);
    }
    
    function handler(e) {
        if (e.target.id == 'test') {
             // the button was clicked
        }
    }
    

    小提琴

    2023-02-13 13:47 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有