这似乎与此处发现的类似问题,但我担心我不理解所提供的解决方案。 Multiple drop events in HTML5
我正在尝试使用Ext JS库从一个拖动源设置多个放置目标。当我为notifyEnter定义闭包时,它似乎总是使用变量“i”来发出警报(我已将其更改为警告以进行调试)。来自Java背景,我的直觉是通过在循环中定义最终变量并在定义闭包之前分配i或者我想要的playerLocationPanel来解决这个问题,但这似乎不是一个有效的解决方案
这是我8到10年来首次涉足Javascript,所以非常感谢您的帮助。
/****
* Setup Drop Targets
***/
var playerPanelDropTargets = new Array();
var dropTargetEls = new Array();
for(var i=0;i<=5; i++){
dropTargetEls[i] = playerLocationPanels[i].body.dom;
playerPanelDropTargets[i] = Ext.create('Ext.dd.DropTarget', dropTargetEls[i], {
ddGroup: 'GridExample',
notifyEnter: function(ddSource, e, date){
// The problem here is that it always calls, specifically playerLocationPanels[i]
// and i is always going to be 1 more than the top of the loop.
//playerLocationPanels[i].body.stopAnimation();
//playerLocationPanels[i].body.highlight();
alert(i);
}
});
}
答案 0 :(得分:0)
您需要采用与您引用的问题中提到的相同的基本方法:您的“notifyEnter”函数需要在您传递“i”的单独函数中创建,并返回处理函数。像这样:
playerPanelDropTargets[i] = Ext.create('Ext.dd.DropTarget', dropTargetEls[i], {
ddGroup: 'GridExample',
notifyEnter: makeHandler(i)
});
// ...
function makeHandler(i) {
return function(ddSource, e, date){
alert(i);
// etc.
};
}
通过调用另一个函数来创建处理函数,可以确保每个处理函数都有自己的“i”值副本。