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

在 forEach -> eventlistener 函数中传递参数

如何解决在 forEach -> eventlistener 函数中传递参数

我该如何解决这个问题?

代码

answerArr.forEach((div,index) => {
    div.addEventListener('click',() => {
      checkAnswer(div,index);
    });
  });

这有效,但我的函数运行了四次。 (因为我有四个 div - 在我的数组中,在 DOM 中)

我怎样才能达到这个结果:(只运行一个函数,但每个 div 仍然有 EventListener)

answerArr.forEach((div,checkAnswer(div,index));
  });

我知道我无法将参数传递给 EventListener。

谢谢!

解决方法

您可以使用 bind() 来确保使用指定的参数调用该函数。

例如:

answerArr.forEach((div,index) => {
    div.addEventListener('click',checkAnswer.bind(null,div,index));
});

bind() 的第一个参数,在本例中为 null,是您将函数的 this 值绑定到的参数。因此,如果您从 this 内部引用 checkAnswer,它将引用第一个参数。

此示例假设您有 4 个不同的 div,每个 div 都需要一个事件侦听器。如果您只有一个 div,则可能只是颠倒结构:

div.addEventListener('click',(event) => {
    // here you can use the "event" arg to get info about what was clicked
    checkAnswer();
});

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 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”。这是什么意思?