首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >添加动态命名的事件侦听器。

添加动态命名的事件侦听器。
EN

Stack Overflow用户
提问于 2014-05-22 09:58:57
回答 1查看 391关注 0票数 0

我正在尝试创建一个可配置的按钮栏,并在每个按钮中添加onclick事件侦听器。我需要动态分配函数,并使用按钮的data-function属性提供的名称。

代码语言:javascript
运行
AI代码解释
复制
<div class="button-set">
  <span class="function-button" data-function="func1"></span>
  <span class="function-button" data-function="func2"></span>
</div>

剧本:

代码语言:javascript
运行
AI代码解释
复制
window.onload = function (){
  var btns = document.getElementsByClassName("function-button");
  for (var i=0; i < btns.length; i++) {
    var b = btns[i];
    b.addEventListener("click", ?????, false);
  }
}

function func1() {}
function func2() {}

那么,在?????中应该做什么,以便将正确的函数添加到每个按钮的onclick事件中?

我想要这个没有jQuery。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-05-22 10:03:39

假设func1func2是全局函数,

代码语言:javascript
运行
AI代码解释
复制
b.addEventListener("click", window[b.getAttributte('data-function')], false);
// Or, in new browsers:
b.addEventListener("click", window[b.dataset.function], false);

如果它们不是全球性的,您应该这样声明:

代码语言:javascript
运行
AI代码解释
复制
var functions = {
    func1: function () {},
    func2: function () {}
}
b.addEventListener("click", functions[b.dataset.function], false);

您可以使用邪恶的eval代替,但最好避免它(较慢和注入易受攻击):

代码语言:javascript
运行
AI代码解释
复制
b.addEventListener("click", eval(b.dataset.function), false);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23814093

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档