【发布时间】:2015-07-25 02:15:09
【问题描述】:
我在 jQuery 中有一个函数,每当我按下任何箭头键时都会触发该函数。以下是“向上”箭头案例的代码,其他三个案例看起来非常相似,都包含在 checkKey 函数中。
document.onkeydown = checkKey;
function checkKey(e) {
var divs = ["one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "ten", "eleven", "twelve", "thirteen", "fourteen", "fifteen"];
e = e || window.event;
if (e.keyCode == '38') {
for (i = 0; i < divs.length; i++){
var tmp = document.getElementById(divs[i]);
var coord = $(tmp).position();
if ((Math.abs(embargo_top - coord.top) < 115) && (Math.abs(embargo_left - coord.left) < 15)){
if(embargo_top < coord.top){
embargo_top = coord.top;
embargo_left = coord.left;
$(tmp).animate({
'top': (parseInt($(tmp).css('top'), 10) - 100) + "px"
}, 500);
break;
}
}
}
checkIfWinner();
}
如何处理这些事件,以便如果我将一堆箭头键组合在一起,则每次执行函数都只会在前一个函数调用完全完成后发生?
【问题讨论】:
标签: javascript jquery