繁体   English   中英

Raphael.js - 向元素注册多个事件

[英]Raphael.js - registering multiple events to element

我的问题是我需要处理矩形的多个事件。 这听起来很简单,例如这有效

  node.click(function(e){
     click(); // this is function defined in same scope, it works ok
  });

  node.mouseout(function(e){
     mouseout();  
  });

但是,我想自动化这个,所以它应该是这样的:

var events = new Array("click", "mouseout");
for(var i in events){
     node[events[i]](function(e){
         events[i](); /*THIS is problem, no matter if it is click or mouseout
                        this always fires function with same name as last item
                        in events array (in this case mouseout) 
                      */
     }
}

你知道我为什么要解决这个问题吗?

在循环中创建的处理程序正在共享变量。 调用它们时,变量是循环中的最后一个值。

你必须使用我称之为“冻结闭包”的技术,以便每个处理程序获得共享变量的单独副本。 在您的情况下,更改的共享变量是i

你的另一个问题是你想从一个字符串中调用你的函数“click / mouseout”,所以你必须得到一个函数的句柄,现在你的代码试图调用"hello"()这不起作用

您的最后一个问题(但尚未出现错误)是您不应使用Array构造函数,并且不应使用for in循环来迭代数组。

function createHandler(eventName) {
    return function(e) {
        window[eventName]();
    }
}

var events = ["click", "mouseout"];
for(var i=0; i < events.length; i++){
     node[events[i]](createHandler(events[i]));
}

上面的例子更容易理解,但你可以使用自调用匿名函数来做同样的事情

var events = ["click", "mouseout"];
for(var i=0; i < events.length; i++){
     node[events[i]]((function(eventName){
         return function(e) {
             window[eventName]();
         };
     })(events[i]));
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM