JS backspace按键事件有时会触发,有时不会触发

时间:2015-01-26 14:10:55

标签: javascript jquery

我有这段代码:

container.unbind('keypress').bind('keypress',function (e) {

            var code = e.which,
                charac = String.fromCharCode(code),
                totalChar = $(this).text().replace(/\s+/g, ''),
                diff,
                previousChar = publisher.typeHistory.length > 0 ? publisher.typeHistory[publisher.typeHistory.length-1]:''
                previousCharCode = previousChar.charCodeAt(0);

            if(e.keyCode === undefined){ // backspace
                getCharacterDiff();
                console.log(totalChar.length-1);
                if(totalChar.length-1 === 0){
                    publisher.typeHistory = [];
                }
            }  

            console.log(previousChar);
            if(isCharacterKeyPress(code)){
                if (charac.toUpperCase() != charac.toLowerCase() ) { // Is a char or space


                    if(charac === charac.toUpperCase()){ // Is a char upper ?

                        if(previousChar === ' '){
                            console.log('upper + previous == space ', publisher.typeHistory);
                        }else {
                            publisher.typeHistory = [];
                        }

                        push = true;
                    }
                    else if (charac === charac.toLowerCase()){
                        if(previousCharCode === 32){
                            publisher.typeHistory = [];

                        }
                        if(hasUpperCase(publisher.typeHistory.join(''))){
                            push = true;
                        }
                        else {
                            push = false;
                        }

                    }
                    else {
                        push = false;
                    }


                }
                else if (code === 32){
                    console.log('space');
                    console.log(previousCharCode);
                    if (previousCharCode === 32){
                        push = false;
                        publisher.typeHistory = [];
                    }

                    // else if(previousChar === 32) { // is the spacebar ?
                    //  console.log(previousChar);

                    // }
                }
                else { // = it's a number / , / ., etc..
                        console.log('not chara or space');
                        push = false;
                        publisher.typeHistory = [];



                }


                if (push) {
                    publisher.typeHistory.push(charac);
                }

            }

            console.log(publisher.typeHistory);
            previousTotal = publisher.typeHistory.join('');


            if (publisher.typeHistory.length > 2) {
                exp = publisher.typeHistory.join('');
                publisher.getResults(service,type,exp);
            }
            else {
                if(publisher.typeHistory.length === 0){
                    publisher.typeHistory = [];

                }
                publisher.hideResults();
            }

    });

有了这个,我处理哪些键在contenteditable=true的元素中输入,然后我将它发送给一个向PHP脚本发出请求的方法。

此处,container可以是contenteditable = true的任何元素。

问题是:我使用e.keyCode === undefined检查用户是否键入退格键,以便我可以更新请求。但e.keyCode === undefined仅适用于单个元素,而不适用于其他元素(另一方面,未触发按键事件)。

所以我不知道它来自何处:

  • 我知道按键事件无法检测退格键按下(但是,在这种情况下,使用此代码,它确实存在)
  • 可以container
  • 的anay元素之间的HTML / JS没有区别
  • 我不能使用keyup / keydown,因为它不区分大小写

我想念什么?

1 个答案:

答案 0 :(得分:2)

来自keypress event:

上的MDN
  

按下某个键并按下该键时会触发按键事件   通常会产生一个字符值

因此,您必须对某些键使用keyupkeydown事件,例如转义或退格,因为它们不会生成字符。

退格键的代码是8,因此您的代码如下所示:

container.unbind('keyup').bind('keyup',function (e) {

    ...

    if(e.keyCode === 8){ // backspace
        getCharacterDiff();
        console.log(totalChar.length-1);
        if(totalChar.length-1 === 0){
            publisher.typeHistory = [];
        }
    }  

    ...

});