如何解决如何将函数侦听器传递给addeventlistener
我有一个可重用的模块,可为我们的网站创建表单顶部。它支持的功能之一是允许其他开发人员在其页面上添加事件处理程序。
我正在对其进行重组,因为我们的网站已包含内联脚本,并且不会通过新的安全要求。
开发人员给了我一个看起来像这样的参数: addEvents =“'onClick = testEvent2()'”
// event converter
var map = new Object();
map["onLoad"] = "load";
map["onKeyUp"] = "keyUp";
map["onClick"] = "click";
var myEvents = [#Attributes.addEvents#];
function iterate(item) {
thisEvent = item.split("=");
document.getElementById("fluid").addEventListener(map[thisEvent[0]],event => {thisEvent[1];});
}
myEvents.forEach(iterate);
function testEvent(){
alert("hi mom");
}
function testEvent2(){
alert("stop touching me!");
}
井号之间的位是文字onClick = testEvent2()。 (这是一个ColdFusion模板) 我要在这里发生的事情是,当用户单击页面上的任意位置时,他们会收到一条警告,提示“停止触摸我”
(显然;这只是我正在研究如何使用的废话处理程序!)
好吧...什么都没发生。如果我将变量thisEvent [1]替换为它包含的文字testEvent2(),则它将按预期工作。
我需要怎么做才能传递对函数的引用?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。