微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何将点击事件处理程序添加到通过javascript创建的我的userChat类中

如何解决如何将点击事件处理程序添加到通过javascript创建的我的userChat类中

我已经使用javascript创建了一个名为userChat的类,我希望能够将click事件处理程序添加到userChat类中,以便当我单击userChat时它将向我发送我所单击的用户名称,问题是我添加一个addEventListener,但是它不起作用,我不知道我在做什么错,请您能帮我,非常感谢。

    function updateUsers(socket){   
    socket.on('updateUsers',function(data){       
        let usuarios = document.querySelector('#usuarios');
        usuarios.innerHTML='';
        for(let i = 0; i < data.users.length; i++){
            let us = `<div class ="userChat">` +data.users[i] +`</div>`;
            usuarios.innerHTML += us;
            

            let userchat = document.querySelector('.userChat');
            userchat.addEventListener('click',function(){
            console.log('estas tocando al usuario: '+data.users[i]);
            });
        }       
    });
    }

解决方法

尝试这种方式

let us = `<div class ="userChat" onclick='getUser(data.users[0])'>` +data.users[i] +`</div>`;


function getUser(user){
  // user
}
,

您正在尝试将事件侦听器添加到刚刚在js中创建的元素(本例中为let us = ...)。您应该将此侦听器添加到该元素的父级中,该父级已经在DOM中,然后可以检查此点击是否由您的元素触发。换句话说,您需要将该事件“委托”到父元素(事件委托)。例如:

 <parent-element>.addEventListener('click',function (e) {
   if (e.target && e.target.classList.contains('userChat')) {
     //do something
   }
 });

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?