事件引用在作为方法传递的事件侦听器回调上未定义

Event reference is undefined on event listener callback passed as a method

本文关键字:事件 侦听器 回调 未定义 引用 方法      更新时间:2023-09-26

当我将事件附加到元素时,没有调用回调方法。有问题的方法属于一个对象,但似乎我称之为方法的方式在单击事件发生时没有被调用。

 var myObject = {
     handledrop : function () {
          
         //retrieved created html element
         var elem = document.getElementById("required");
         elem.addEventListener("click", this.deleteFavorite.bind(this), false);
     },
     //this method isn't being called when click event occurs
     deleteFavorite: function (evt) {
        console.log(evt);
     }
 }

我做错了什么?如何传递正确的上下文,以便调用正确的方法并传递正确的上下文,即事件

几个调试/故障排除技巧:

  1. 发布"必需"元素的 html。
  2. 检查您认为获得的"必需"元素是否有效:

    var elem = document.getElementById("required");
    console.log('elem:',elem);
    
  3. 您还可以迭代其属性以确保函数存在:

    foreach(var property in elem){
        console.log('property:',property);
    }
    

对于跨浏览器支持 - 您可能需要阅读这篇文章:addEventListener vs onclick