解读event.returnValue和return false

前言

首先我们要清楚returnValue是IE的一个属性,如果设置了该属性,它的值比事件句柄的返回值优先级要高,把它的值设置为false,可以取消发生事件源元素的默认动作;return false就是返回一个false值。

定义

returnValue:设置或获取事件的返回值。

进一步可以这样理解:event对象的returnValue属性一般为true,表示脚本处理完自己的工作由元素来处理事件,通过该属性可以取消事件处理程序中调用函数的默认操作。

作用

event.returnValue:当捕捉到事件(event)时会做一些判断,判断失败,则会阻止事件继续执行,可以达到的效果是“不能在输入框中输入非数字字符”,window.event.returnValue=false放在提交表单中的onclick事件中则不会提交表单,如果放到超链接中则不执行超链接。

<html>
<head>
<script language="text/javascript">
    return_value(){
        var charCode=event.keyCode;
        if(charCode<48||charCode>75){
            alert("对不起,你输入的不是数字字符!");
            event.returnValue=false;
        }  
    }   
</script>
</head>
<body>
    <textarea name="textarea" onKeyPress="return_value()">            
    </textarea>
</body>
</html>                

如果没有event.returnValue=false;这句填写的字符不是数字也会在文本框显示,加上这句,不是数字就不会在文本框中显示,代码会执行完但事件的操作不会继续下去了。

return false:禁止一些浏览器的默认行为,由于原先默认的行为是ture,例如,<a>链接,点击事件发生后,紧接着的默认事件就是跳转链接,但是,在onclick=function(){return false;}之后,就可以对紧接着的默认行为禁止掉;

区别

这个event.returnValue与return false的区别是,在实战中,对表单验证而言,event.returnValue=fasle和return function(){return false}的效果是一样的,都是先对表单的内容进行判断,才决定是否执行下去,但是,这个return function(){return false}和function(){return false}又是有区别的,前者是在先对函数的内容的判断上是否执行下去的,但是,后者则不会进行判断就直接执行下去了

扩充

例如:onClick='return add_onclick()'与 onClick='add_onclick()'的区别

js在事件中调用函数时用return返回值实际上是对window.event.returnvalue进行设置。而该值决定了当前操作是否继续。当返回的是true时,将继续操作。当返回是false时,将中断操作。

而直接执行时(不用return)。将不会对window.event.returnvalue进行设置,所以会默认地继续执行操作

详细说明如下:
当在 <a href="abc.htm" onclick="return add_onclick()">Open</a> 中
如果函数 add_onclick() 返回 true, 那么 页面就会打开 abc.htm
否则, (返回 false), 那么页面不会跳转到 abc.htm, 只会执行你的 add_onclick() 函数里的内容. (add_onclick函数中控制页面转到 abc.htm除外)

而 <a href="abc.htm" onclick="add_onclick()">Open</a>
不管 add_onclick() 返回什么值, 都会在执行完 add_onclick 后打开页面 abc.htm

注:onclick和href同时存在时,先执行onclick再执行href

另外补充:
1、onclick事件时就相当于onclick="return true/false"

function check(){
        if(obj.value=="" ){
             window.alert("不能为空!");
             obj.focus();
             return false;
        }
        return true;
}            

调用方法返回true时才提交表单,反之则不提交,这是submit按钮

2、调用js函数不需要return,但是表单却无法提交,所以在js函数中加上一句话

<script language="javascript">
    function check(){
        if(obj.value=="" ){
             window.alert("不能为空!");
             obj.focus();
             return false;
       }
       document.myform.submit();
       return true;
}
</script>            

注:document.myform.submit();要在return true前

原文地址:https://www.cnblogs.com/kunmomo/p/10183364.html