如何在firefox中检测keyevent

时间:2012-06-18 03:36:13

标签: javascript firefox

我用javascript写了一个web shell,但它在firefox中不起作用。但在IE和Chrome中,它很好。我发现在firefox中我的脚本无法获得keyevent。那么我该如何修复这个bug呢?非常感谢:)

Shell:http://cdqzoi.com

脚本地址:http://cdqzoi.com/console.js 以下代码是上述脚本的一部分,它处理keyevent。

this.keydown=function(){
    key=event;
    keyN=event.keyCode?event.keyCode:event.which?event.which:event.charCode;
    if(keyN==0)return;
    if((keyN==8)||(keyN==116)||(key.ctrlKey && keyN==82)){
        if(keyN==8 & !lock){
            this.command = this.command.substr(0,this.command.length-1);
            document.getElementById("console").innerHTML=getPrefix(this.transmit)+this.command;
        }
        try{
            event.returnValue=false;
            event.keyCode=0;
        }catch(e){
            event.preventDefault();
        }
    }
    keyN=0;
}
this.keypress=function(){
    key=event;
    keyN=event.keyCode?event.keyCode:event.which?event.which:event.charCode;
    if(keyN==0)return;
    if(!lock){
        if(keyN==13){
            if(this.transmit==0){
                user=this.command;
                document.getElementById("_console").innerHTML+=document.getElementById("console").innerHTML+"<br />";
                document.getElementById("console").innerHTML='';
                this.transmit=1;
                this.st=1;
            }else
            if(this.transmit==1){
                this.st=0;
                pass=this.command;
                document.getElementById("_console").innerHTML+=document.getElementById("console").innerHTML+"<br />";
                document.getElementById("console").innerHTML="";
                con.login(user,pass);
                try{
                    event.returnValue=false;
                    event.keyCode=0;
                }catch(e){
                    event.preventDefault();
                }
                keyN=0;
                return;
            }else
            if(this.transmit==2){con.execute(this.command);}
            this.command='';
        }else if(keyN==8){
        }else{
            this.command=this.command+String.fromCharCode(keyN);
        }
        if(this.st==0)document.getElementById("console").innerHTML=getPrefix(this.transmit)+this.command;
        else document.getElementById("console").innerHTML=getPrefix(1);
    }
    try{
        event.returnValue=false;
        event.keyCode=0;
    }catch(e){
        event.preventDefault();
    }
    keyN=0;
}

1 个答案:

答案 0 :(得分:0)

写下你的处理程序:

this.keypress = function(e) {
  var ev = window.event || e;
  // use ev from here onwards

原因是IE(显然,Chrome也选择通过全局变量而不是函数参数传递事件数据)。