8

我正在尝试修复一个 jQuery UI 小部件上的一个非常奇怪的 javascript 行为。IE7(win XP),jQuery 1.2.6(是的,它是旧版本)。

小部件是一个组合框,它捕获键盘事件并具有箭头键的特殊行为。

当我尝试在 flexbox 输入字段中键入“&”字符时,我得到了奇怪的行为。

flexbox 有一些代码,例如:

//initialization
$myInputElement.keypress($.flexbox.process_key);
$.flexbox.process_key = function process_key(e) {
    $.flexbox.flexboxFromInput(this).processKey(e);
    return true;
};

//on the flexbox object's prototype:
...
    processKey: function processKey(e) {
        var mod = 0;
            if (typeof (e.ctrlKey) !== 'undefined') {
                if (e.ctrlKey) mod |= 1;
                if (e.shiftKey) mod |= 2;
            } else {
                if (e.modifiers & Event.CONTROL_MASK) mod |= 1;
                if (e.modifiers & Event.SHIFT_MASK) mod |= 2;
            }
            ...
            switch (e.keyCode) {
                   case 38: // up
                       this.prevResult();
                       break;
                   case 40: // down
                       if (this.getCtr().is(':visible')) this.nextResult();
                       else this.flexboxDelay(true);
                       break;
               ...etc.
           }
    }
...

当我引入日志语句时,我发现按“&”(shift+7)会产生三个按键事件:

INFO: Flexbox> processKey, keyCode=16, ctrl=false, shift=true
INFO: Flexbox> processKey, keyCode=55, ctrl=false, shift=true
INFO: Flexbox> processKey, keyCode=38, ctrl=false, shift=true

显然,keyCode 38 既是向上箭头键又是 & 的 ASCII 码??

在我写这篇文章时,我突然想到我可以将按键检测为“shift+7”(keyCode 55)以将其视为 & 键,然后设置某种标志以忽略下一个按键(即 38 )。这似乎是一个可怕的黑客攻击。

有没有人有更好的方法来区分特殊字符,如“&”和 IE 中的箭头键?

4

4 回答 4

3

这就是我最终做的事情:

    /*
     * Hack around a wierd behavior in IE where "&%'(" have the same keyCodes
     * as the arrow keys.
     */
        if (keyCodeIn(e.keyCode, 55, 53, 57) && (mod & 2) && !(mod & 1)) {
            this.ignoreNextArrowKey = true;
        }
        else if (222 === e.keyCode && !(mod & 2) && !(mod & 1)) {
            this.ignoreNextArrowKey = true;
        }
        else if (keyCodeIn(e.keyCode, 38, 37, 39, 40) && this.ignoreNextArrowKey) {
            this.ignoreNextArrowKey = false;
            return;
        }

        //...

        function keyCodeIn(keyCode) {
            for(var i = 1; i < arguments.length; i++) {
                if (arguments[i] === keyCode) {
                    return true;
                }
            }
            return false;
        }

希望这可以帮助某人。如果您要重用此代码,您可能需要调整关键字“this”的使用,具体取决于它所指的对象(这里,它是与 flexbox 小部件关联的 javascript 对象)。

编辑:我更新了这段代码,并删除了以前存在的正则表达式测试,我发现这是错误的。

于 2010-03-04T00:38:22.130 回答
2

我认为keydown可能会给你比keypress.

于 2010-03-04T00:15:51.553 回答
1

我建议使用这个 jquery 库为按键编写自定义处理程序: http ://code.google.com/p/js-hotkeys/

试图从逻辑上辨别键码是一场噩梦。

于 2010-03-04T11:44:28.737 回答
0

key up 或 down 为 '&' 返回 55 的 keyCode 和 'Arrow Up' 的 38

于 2010-03-04T02:54:49.253 回答