javascript中的return、return true、return false、continue区别
1、语法为:return 表达式;
2、w3c中的解释:
语句结束函数执行,返回调用函数,而且把表达式的值作为函数的结果
也就是:当代码执行到return语句时,函数返回一个结果就结束运行了,return后面的语句根本不会执行。
举个栗子:
|
1
2
3
4
5
6
|
function myFun() { console.log("Hello"); return "World"; console.log("byebye")}myFun(); |
上面代码输出“Hello”到控制台,返回“World”,但没有输出“byebye”,因为函数遇到return语句就退出了。
3、return false:
在大多数情况下,为事件处理函数返回false,可以防止默认的事件行为.例如,默认情况下点击一个<a>元素,页面会跳转到该元素href属性指定的页。
js中return false作用一般是用来取消默认动作 / 阻止提交表单 / 阻止继续执行下面的代码。
注意:return false 只在当前函数有效,不会影响其他外部函数的执行。
举个栗子说明:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
function a(){ if(True) return false;}这是没有任何问题的,如果我改成这种function Test(){ a(); b(); c();} |
即使a函数返回return false 阻止提交了,但是不影响 b()以及 c()函数的执行。在Test()函数里调用a()函数,那面里面
return false 对于Test()函数来说,只是相当于返回值。而不能阻止Test()函数执行。
return false 返回错误的处理结果,终止处理。 就相当于终止符,
4、return true:
return true 返回正确的处理结果,就相当于执行符。
5、return:把控制权返回给页面。
6、关于阻止浏览器执行默认行为
大家对事件冒泡都很熟悉了吧,我想表达的是大部分事件都是先在初始DOM上触发,然后再通过DOM树往上,在每一级父元素上触发,事件不会在兄弟节点或是子节点上冒泡(当事件向下冒泡时,我们叫它事件捕捉(event capturing)),
“return false”之所以被误用的如此厉害,是因为它看起来像是完成了我们交给它的工作,浏览器不会再将我们重定向到href中的链接,表单也不会被继续提交,但这么做到底有什么不对呢?
7、”return false“到底做了什么?
当你每次调用”return false“的时候,它实际上做了3件事情:
•event.preventDefault();
•event.stopPropagation();
•停止回调函数执行并立即返回。
“等等”,你叫了起来!我只是想让浏览器停止继续执行默认行为而已,我不需要它去做另外2件事。
这3件事中用来阻止浏览器继续执行默认行为的只有preventDefault,除非你想要停止事件冒泡,否则使用return false会为你的代码埋下很大的隐患,让我们通过一个真实的例子来看看这样的误用会造成什么后果:
<div class="post">
<h2><a href="http://jb51.net">My Page</a></h2>
<div class="content">
Teaser text...
</div>
</div>
<div class="post">
<h2><a href="http://jb51.net">My Other Page</a></h2>
<div class="content">
Teaser text...
</div>
</div>
现在假设我们想要在用户点击文章标题时,将文章动态载入到div.contentd中:
|
1
2
3
4
5
6
7
8
9
|
jQuery(document).ready(function ($) { $("div.post h2 a").click(function () { var a = $(this), href = a.attr('href'), // Let jQuery normalize `href`, content = a.parent().next(); content.load(href + " #content"); return false; // "cancel" the default behavior of following the link }); }); |
这段代码可以正常工作(至少目前是),但如果我们顺着这个思路继续,如果我想要在用户点击了一个div.post元素(或者任何一个它的子元素)时,给它加上一个active类,我就需要给div.post增加了一个click回调:
|
1
2
3
4
5
|
var posts = $("div.post"); posts.click(function () { posts.removeClass("active"); $(this).addClass("active"); }); |
现在,如果我们点击一个帖子的标题,这段代码会工作吗?答案是不会,因为我们在标题的click回调里使用了return false而不是我们应该使用的,”return false“等于event.preventDefault();加event.stopPropagation();,所以事件冒泡就被终止了,click事件不会被冒泡到div.post上,我们为它添加的事件回调当然也就不会被调用了。
那先来了解下什么是preventDefault():
preventDefault()
大多数情况下,当你使用return false时,你其实真正需要的是e.preventDefault()。要使用e.preventDefault,你需要确保你传递了event参数到你的回掉函数中(在这个例子里,就是那个e):
|
1
2
3
4
|
$("a").click(function (e) { // e == our event data e.preventDefault(); }); |
它会替我们完成所有工作,但不会阻止父节点继续处理事件,要记住,你放在代码中的限制越少,你的代码就越灵活,也就越易于维护。
stopPropagation()
定义:不再派发事件。
终止事件在传播过程的捕获、目标处理或起泡阶段进一步传播。调用该方法后,该节点上处理该事件的处理程序将被调用,事件不再被分派到其他节点。
该方法将停止事件的传播,阻止它被分派到其他 Document 节点。注意,虽然该方法不能阻止同一个 Document 节点上的其他事件句柄被调用,但是它可以阻止把事件分派到其他节点。
8、什么时候用 return false?
只有当你同时需要preventDefault和stopPropagation,并且你的代码可以接受直到你的回调执行完成才停止执行浏览器的默认行为,那你就可以使用”return false“。
return、continue、break 、continue 的区别
return :
continue :
终止本次循环的执行,即跳过当前这次循环中continue语句后尚未执行的语句,接着进行下一次循环条件的判断。
它不是退出一个循环,而是开始循环的一次新迭代。
continue语句只能用在while语句、do/while语句、for语句、或者for/in语句的循环体内,在其它地方使用都会引起错误!
举个栗子:
1.语法及返回方式
①返回控制与函数结果
语法为:return 表达式;
语句结果函数的执行,返回调用函数,而且把表达式的值作为函数结果返回出去
②返回控制无函数结果
语法为:return;
在大多数情况下,为事件处理函数如果让其返回false,可以防止默认的事件行为.例如,默认情况下,点击一个<a>标签元素,页面会跳转到该元素href属性指定的页. 而return false就相当于终止符,return true就相当于执行符. 在js中return false的作用一般是用来取消默认动作的.比如你单击一个链接除了触发你的"onclick"事件以外还要触发一个默认事件就是执行页面的跳转.所以这时候如果你想取消对象的默认动作就可以return false来阻止它的动作.也就是说如果你想用js代码来局部改变一些数据而不引起页面其他部位的变化,那么你就应该在onclick事件代码的后面加上return false;
在js中,我们通常用return false来阻止提交表单或者继续执行下面的代码,通俗来说就是阻止执行默认的行为.
|
1
2
3
4
5
6
7
8
9
10
|
function s1(){ if(true){ return false; }}function s2(){ m(); n(); p();} |
上面两个例子,函数s1那样写没有问题的,if函数体里返回出去false,终止函数.而在函数s2里,如果我们在m函数里返回一个return false阻止提交,但是这并不影响函数n和函数p的执行.在s2函数里调用函数m,那里面的return false对于函数s2来说,只是相当于返回值,并不能阻止函数s2的执行.return false只在当前函数有效,并不会影响其他外部函数的执行.
总结:
return true;返回正常的处理结果.
return false;返回错误的处理结果;终止处理;阻止提交表单;阻止执行默认的行为.
return;把控制权返回给页面.
2.通常函数经过一系列的处理后需要给外部返回一个值,这个值一般用return返回出去,也可以是说return是向函数返回返回值,并终止函数的运行.
关于return,要注意的是在函数里return后面的内容是不再执行的.
|
1
2
3
4
5
|
function a(){ return 10; document.write(50);//不执行 }a();//10 |
上面的例子中,"return 10;"这个时候函数a的值会等于10,并且函数下面的内容不再执行,因为下面运行函数a时输入10.
究竟需不需要return来返回值,要看函数是来做什么,如果需要让它返回一个值就写return,如果不需要它返回值,就没必须写它.
|
1
2
3
4
5
6
7
8
9
10
11
|
function a(b,c){ return b+c;}var abc=a(5,8);console.log(abc);//13function a(b,c){ document.write(b+c);}var abc=a(5,8);//此时页面上会输出13,但其实abc是没有值的console.log(abc);//undefined |
当然,js中的return不一定非得用在函数function中,有时候也可以用来阻止某些动作,比如表单的提交,让表单的提交事件返回false,那表单就不会提交:onsubmit="return false";
for(var i=1;i<=10;i++) {
if(i==8) {
continue;
}
document.write(i);
}
//当i=8的时候,直接跳出本次for循环。下次继续执行。
//输出结果:1234567910
break :
1 for(var i=1;i<=10;i++) {
2 if(i==8) {
3 break;
4 }
5 document.write(i);
6 }
7
8 //当i=8的时候,直接退出for这个循环。这个循环将不再被执行!
9 //输出结果:1234567


浙公网安备 33010602011771号