[英]Detect multiple keys on single keypress event in jQuery
是否可以结合使用按键的混合物来发射单个事件?
$(document).keyup(function(e){
if (e.keyCode == 68 && e.keyCode == 69 && e.keyCode == 86) {
alert('oh hai');
}
});
我在Chrome中尝试过,但事件并未触发。
叫我疯了,但我正在编写一个Chrome扩展程序,并希望将D + E + V键推到一起,以强制它进入隐藏的开发者模式。
如果要检测d , e和v键是否同时全部关闭,则必须同时观察keydown
和keyup
并保留已关闭的键的映射。 当他们全部失败时,解雇你的活动。
var map = {68: false, 69: false, 86: false};
$(document).keydown(function(e) {
if (e.keyCode in map) {
map[e.keyCode] = true;
if (map[68] && map[69] && map[86]) {
// FIRE EVENT
}
}
}).keyup(function(e) {
if (e.keyCode in map) {
map[e.keyCode] = false;
}
});
我假设你不关心他们被压下的顺序(因为这可能是一种痛苦,可靠地按下),只要他们在某个时刻同时处于同一时间。
与Vega相似......但更简单
var down = {};
$(document).keydown(function(e) {
down[e.keyCode] = true;
}).keyup(function(e) {
if (down[68] && down[69] && down[86]) {
alert('oh hai');
}
down[e.keyCode] = false;
});
也许更简单的组合键会更容易?
Shift + Alt + D怎么样? (您可能不应该使用Control键,因为大多数浏览器已经以某种方式解释Ctrl + D)
这个代码是这样的:
if(e.shiftKey && e.altKey && e.keyCode == 68)
{
alert('l33t!');
}
我在简单的javascript中为TJ Crowder回答了那些想要避开Jquery的人 。
//A W S D simultaneously
var map = {65: false, 87: false, 83: false, 68: false};
document.body.addEventListener('keydown', function (e) {
var e = e || event; //to deal with old IE
if (e.keyCode in map) {
map[e.keyCode] = true;
if (map[65] && map[87]) {
console.log('up left');
}else if (map[83] && map[68]) {
console.log('down right');
}else if (map[87] && map[68]) {
console.log('up right');
}else if (map[83] && map[65]) {
console.log('down left');
}
}
});
document.body.addEventListener('keyup', function (e) {
if (e.keyCode in map) {
map[e.keyCode] = false;
}
});
您需要分别捕获三个关键事件,并仅在第三个事件之后触发您的操作。
var keys = {
d: { code: 100, pressed: false, next: 'e' },
e: { code: 101, pressed: false, next: 'v' },
v: { code: 118, pressed: false, next: 'd' }
},
nextKey = 'd';
$(document).keypress(function(e) {
if (e.keyCode === keys[nextKey].code) {
keys[nextKey].pressed = true;
nextKey = keys[nextKey].next;
} else {
keys.d.pressed = false;
keys.e.pressed = false;
keys.v.pressed = false;
nextKey = 'd';
}
if (keys.d.pressed && keys.e.pressed && keys.v.pressed) {
alert('Entering dev mode...');
}
});
当然,有很多方法可以做到这一点。 此示例不要求您同时按住键,只需按顺序键入它们: d e v 。
如果你使用了这个,你可能想要增加它以在一段时间间隔后清除pressed
标志。
这是一个有效的例子 。
免责声明:我意识到原来的问题是钥匙应该“压在一起”。 这只是一种替代方案,因为其他应答者已经为按键组合提供了足够的解决方案。
我尝试了三个最佳答案(截至本文),但没有一个能为我工作。 他们没有重置密钥 。
如果用3个键激活脚本,则在触发一次后 - 按下3个键中的任何一个键将再次触发它。
我刚刚写了这个脚本,它运行得很好。 它使用Shift + S来触发,但你可以轻松改变它。 按下组合后重置。
var saveArray = new Array();
saveArray[0] = false;
saveArray[1] = false;
$(document).ready(function(){
$(document).keydown(function (f){
if (f.keyCode == 16) {
saveArray[0] = true;
}
});
$(document).keyup(function (g){
if(g.which == 16){
saveArray[0] = false;
}
});
$(document).keydown(function (h){
if (h.keyCode == 83) {
saveArray[1] = true;
if(saveArray[0] == true && saveArray[1] == true){
saveArray[0] = false;
saveArray[1] = false;
keypressSaveFunction();
}
}
});
$(document).keyup(function (i){
if (i.which == 83) {
saveArray[1] = false;
}
});
});
function keypressSaveFunction(){
alert("You pressed Shift+S");
}
小提琴: http : //jsfiddle.net/9m8yswwo/13/
const multipleKeypress = (function($document) { // Map of keys which are currently down. const keymap = {} // Update keymap on keydown and keyup events. $document.on( "keydown keyup" // If the key is down, assign true to the corresponding // propery of keymap, otherwise assign false. ,event => keymap[event.keyCode] = event.type === "keydown" ) // The actual function. // Takes listener as the first argument, // rest of the arguments are key codes. return (listener, ...keys) => $document.keydown(() => { // Check if every of the specified keys is down. if (keys.every(key => keymap[key])) listener(event) }) // Pass a jQuery document object to cache it. }($(document))) // Example usage: multipleKeypress(() => console.log("pressed"), 68, 69, 86) // Automatically focus the snippet result window.focus()
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <p>Try pressing <kbd>d</kbd>, <kbd>e</kbd> and <kbd>v</kbd> at once.</p>
如果我很好理解:示例小提琴, http : //jsfiddle.net/gAtTk/ (看看你的js控制台)
这个代码会让你输入单词“ dev
”(在这个例子中,在最后的事件keyup
被删除)
(function(seq) {
var tmp = seq.slice();
$(document).on("keyup.entersequence", function(e){
if (!(e.keyCode === tmp.pop())) {
tmp = seq.slice();
}
else {
console.log(e.keyCode);
if (!tmp.length) {
console.log('end');
$(document).off("keyup.entersequence");
}
}
});
}([68,69,86].reverse()));
您应该使用keydown和keyup事件来“同时”处理多个密钥。
input.on("keydown", function (e) {
if (e.which == 17) {
isCtrl = true; // Ctrl
return;
}
/* Ctrl and "c" */
if (isCtrl && e.which == 67) {
//some code
}
}).keyup(function (e) {
if (e.which == 17) {
isCtrl = false; // no Ctrl
}
});
使用此代码可以在100ms后按下多次按键+超时触发事件以防止错误输入。 在此示例中:如果在100ms的时间段内按下A,Z,E,则将触发事件。
var map = {65:false,90:false,69:false}; //Modify keyCodes here
$(document).keydown(function(e){
console.log(e.keyCode);
map[e.keyCode] = e.keyCode in map ? true : map[e.keyCode] || false;
var result = Object.keys(map).filter(function(key){
return map[key];
}).length === Object.keys(map).length ? true : false;
if(result){
//Your event here
Object.keys(map).forEach(function(key){
map[key] = false;
});
}
setTimeout(function(){
map[e.keyCode] = false;
},100);
});
如果您关心订单并且还需要按住一个键并点击另一个键(例如:Shift + DEL,DEL,DEL ...),而无需抬起第一个键以使事件再次触发......我修改了@ BlakePlumm的[小提琴]评论,延长了@ lu1s对@ ParthThakkar答案的评论。
此外,使用jQuery的.on()允许您仅在某些元素上侦听键序列。 将'body'更改为'input.selector'或其他任何内容。
var map = [];
var down = [];
$(document).on('keydown','body', function(e) {
if(!map[e.which]){
down.push(e.which);
if(down[0] === 68 && down[1] === 69 && down[2] === 86) {
console.log('D + E + V');
} else if(down[0] === 16 && down[1] === 46) {
console.log('SHIFT + DEL');
}
/* more conditions here */
}
map[e.which] = true;
}).keyup(function(e) {
map[e.which] = false;
/* important for detecting repeat presses of
last key while holding first key(s)
(can be shortened. see fiddle) */
var len = down.length;
while (len--) {
if(down[len] === e.which) down.splice(len,1); //removes only the keyup'd key
}
$('.alert').html('');
});
其他想法:如果你只关心订单 - 也就是说,只要你的主要事件触发键最后被按下(第一个按键就像CTRL + SHIFT + TAB,TAB,TAB一样),只需要关闭第一个键,添加此条件:
else if(down.length>2) {
if($.inArray(68,down)!=-1 && $.inArray(69,down)!=-1 && down[2] === 86) {
$('.alert').html('A hacky D+E+V was pressed');
}
}
提供更多光荣的选项和现场演示: - http://jsfiddle.net/kstarr/4ftL1p3k/
https://github.com/JesseBuesking/jquery.hotkeys.extended
看一下这个。 你可能正在寻找这个。
我们可以在多个按键上触发功能。 例如:p + t + k
$(document).hotkeys('p', 't', 'k', function (){
//show blurbox
$('#popup').blurbox({
blur: 10, animateBlur: true, bgColor: 'rgba(255,255,0,0.2)'
})bb.show();
});
也许你正在寻找这个。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.