JS跳出循环的三种方法(break, return, continue)
来源:互联网 发布:js控制标签显示隐藏 编辑:程序博客网 时间:2024/05/17 22:18
JS跳出循环的三种方法(break, return, continue)
前言:
- 一位前端界的大神让我去思考的一个问题, 给了Big-man一段代码,如下:
function Seriously(options) { // if called without 'new', make a new object and return that if(window === this || !(this instanceof Seriously) || this.id !== undefined) { return new Seriously(options); }}
return
语句执行之后还会继续执行吗?这是大神上来让我解决的问题,既然提到了return
那我也就随带解决JS中另外的两种结束循环的方法break
,continue
。
Break
语句:
break
语句会使运行的程序立刻退出包含在最内层的循环或者退出一个switch
语句。- 由于它是用来退出循环或者
switch
语句的, 所以只有当它出现在这些语句的时候, 这种形式的break
语句才是合法的。 - 如果一个循环的终止条件非常复杂, 那么使用
break
语句来实现某些条件比用一个循环表达式所有的条件容易得多。
for(var i = 519; i < 550; i++) { if(i == 522) { break; } console.log(i); alert(i); document.write(i);}
- 当
i = 521
的时候,直接退出for
这个循环。这个循环将不再被执行。 - 对于输出结果的话,可以自己去测试的吧。
Continue
语句:
continue
语句和break
语句相似。所不同的是,它不是退出一个循环,而是开始循环的一次新迭代。continue
语句只能用在while
语句、do/while
语句、for
语句、或者for/in
语句的循环体内, 在其他地方使用都会引起错误?
for(var i = 5; i >=0; i--) { if(i == 4 || i == 3 || i == 1) { continue; } console.log(i); alert(i); document.write(i);}
- 当
i = 4
、i = 3
以及i = 1
的时候,直接跳出for
循环。下次继续执行。 - 至于输出结果,还希望大家去打印一下。
Return
语句:
return
语句就是用于指定函数返回的值。return
语句只能出现在函数体内,出现在代码中的其他任何地方造成语法错误!
for(var i = 1; i < 10; i++) { if(i == 8) { return; } console.log(i); alert(i); document.write(i);}
- 执行结果
Uncaught SyntaxError: illegal return statement(...)
- 错误意思是非法捕获的查询返回语句。
- 当执行
return
语句时, 即使函数主题中还有其他语句, 函数执行也会停止!
<script type="text/javascript"> if(username == "") { alert("please input your username: "); return false; } else if (qq == "") { alert("please input your qq number: "); return false; }</script>
- 上面的实例里,当
username
为空时,就不会再向下执行,在一些表单提交中,也可以通过return false
来阻止默认的提交方式,改用Ajax的提交方式,例如:
<form id="form" onSubmit="return false">...</form>
this
对应的全局变量:
window == this
这个Boolean
等式,在不同的情况下的展现都不一样的。
<!DOCTYPE html><html><head> <title></title></head><body><script type="text/javascript"> function a() { console.log(window === this) } a();</script></body></html>
- 这个时候的
window === this
打印出来的是true
,这也就意味着this
绝对等于window
。
<!DOCTYPE html><html><head> <title></title></head><body><script type="text/javascript"> 'use strict' function a() { console.log(window === this) } a();</script></body></html>
- 这个时候
window === this
返回回来的值却是false
, 而且打印出来的this
是undefined
的。 - 所以严格模式下面的代码操作需要更加的规范和合理才可以的。
Jackdan9 Thinking
阅读全文
0 0
- JS跳出循环的三种方法(break, return, continue)
- js跳出循环的方法区别(break,continue,return)
- js跳出循环的方法区别(break,continue,return)
- js跳出循环的方法区别(break,continue,return)
- 【转载】js跳出循环的方法区别(break,continue,return)
- js跳出循环:break 、continue 、return
- js跳出循环的方法区别(break,continue,return)区分函数体内和循环体内的区别
- 【web前端】js跳出循环:break 、continue 、return
- PHP跳出循环的方法及continue、break、exit、return的区别
- Java跳出循环语句break、continue、return
- break、continue跳出循环的深入学习
- 多层循环的跳出(return goto break continue 的用法与区别)
- PHP中跳出多重循环使用break,continue,goto,return,exit的用法和区别
- [PHP学习]PHP中跳出循环break,continue,return,exit的区别
- String break continue 跳出单循环和跳出多循环方法
- 走出循环结构的几种方法:continue,break,goto,return
- 循环中break,continue,return的区别
- 跳出语句:go to,break,return,continue的差别
- 【nginx】nginx与apache详细性能对比
- 获取从服务器传来的key-value对
- ajax+post+json+@requestBody走天下
- javascript各种设计模式
- 第二次自考总结
- JS跳出循环的三种方法(break, return, continue)
- 2017-2018 ACM-ICPC, NEERC, Southern Subregional Contest (Online Mirror, ACM-ICPC Rules, Teams Prefer
- 斯坦福机器学习笔记 第2周 五、Octave教程(一)
- Python视觉处理(四)HSV处理
- sublime VI编辑器 十分钟熟练掌握各种命令
- zlib库 在windows下的编译与使用
- linux多线程编程基础函数介绍
- 笔记:pringMVC执行流程解析
- Java基础总结