[英]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.