为什么 js方法必须在家alert()才能有效?

  //处理键盘事件 禁止后退键(Backspace)密码或单行、多行文本框除外
    function banBackSpace(e){  
        alert(1);//  这一行去掉之后 就无法执行 
        var ev = e || window.event;//获取event对象   
        var obj = ev.target || ev.srcElement;//获取事件源   
        var t = obj.type || obj.getAttribute('type');//获取事件源类型  
        //获取作为判断条件的事件类型
        var vReadOnly = obj.getAttribute('readonly');
        //处理null值情况
        vReadOnly = (vReadOnly == "") ? false : vReadOnly;
        //当敲Backspace键时,事件源类型为密码或单行、多行文本的,
        //并且readonly属性为true或enabled属性为false的,则退格键失效
        var flag1=(ev.keyCode == 8 && (t=="password" || t=="text" || t=="textarea") 
                    && vReadOnly=="readonly")?true:false;
        //当敲Backspace键时,事件源类型非密码或单行、多行文本的,则退格键失效
        var flag2=(ev.keyCode == 8 && t != "password" && t != "text" && t != "textarea")
                    ?true:false;        

        //判断
        if(flag2){
            return false;
        }
        if(flag1){   
            return false;   
        }   
    }

    window.onload=function(){
        //禁止后退键 作用于Firefox、Opera
        document.onkeypress=banBackSpace;
        //禁止后退键  作用于IE、Chrome
        document.onkeydown=banBackSpace;
    }

因为代码是异步执行的,没有alert(1);前面的没有执行完

浏览器问题吧,我这边没问题

getAttribute('readonly');如果没有设置过readonly属性会返回null(或者设置为true什么的也和你下面的 && vReadOnly=="readonly"冲突,虽然也是只读的),null==''为false,改成obj.readOnly属性(true/false)

        var vReadOnly = obj.readOnly//getAttribute('readonly');
        ///处理null值情况
        ////////vReadOnly = (vReadOnly == "") ? false : vReadOnly;
        //当敲Backspace键时,事件源类型为密码或单行、多行文本的,
        //并且readonly属性为true或enabled属性为false的,则退格键失效
        var flag1=(ev.keyCode == 8 && (t=="password" || t=="text" || t=="textarea")
                    && vReadOnly ) ? true : false;