整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

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的。

所以严格模式下面的代码操作需要更加的规范和合理才可以的。

vector illustration web development shield sign

---------------------

作者:JD9

来源:CSDN

原文:https://blog.csdn.net/XXJ19950917/article/details/78310346

版权声明:本文为博主原创文章,转载请附上博文链接!

avaScript —— 极简主义


看过上一篇文章评论内容的朋友,就会明白我为什么会在这个时候穿插去写这篇文章!越基础的东西就越容易被大家忽视,哪里是忽视,明明是我们从心底瞧不起它;好了,朋友,请收起我们那骄傲自大、不可一世、眼高手低的心态,掌握的牢固不牢固我们自己心里还不清楚吗?先嘲笑下自己,给自己降降温,然后以空杯的心态去面对每一个细小的知识点,come on!

点关注,不迷路哦~

let arr = [1, 2, 3, 4, 5, 6, 7, 8, 9, 1, 2];
let len = arr.length;

1、continue

特点:终止当前循环体,继续去执行下一个循环。

for(let i = 0; i < len; i++) {
 if( arr[i] > 5 ) {
 continue;
 }
 console.log(arr[i])
}

结果:1, 2, 3, 4, 5, 1, 2

2、break

特点:退出包含在最内层(就近原则)的循环

for(let i = 0; i < len; i++) {
 if( arr[i] > 5 ) {
 break;
 }
 console.log(arr[i])
}

结果:1, 2, 3, 4, 5

写到这里应该看出来continue和break的差别了吧,自己去观察,最后我再作总结;接下来我们继续进一步来挖掘什么是就近原则?

for(let k = 0; k < 2; k++){
 for(let i = 0; i < len; i++) {
 if( arr[i] > 5 ) {
 break;
 }
 console.log(arr[i])
 }
}
结果:1, 2, 3, 4, 5, 1, 2, 1, 2, 3, 4, 5, 1, 2

for(let k = 0; k < 1; k++){
 if ( k > 1 ) {
 break;
 }
 for(let i = 0; i < len; i++) {
 console.log(arr[i])
 }
}
结果:1, 2, 3, 4, 5, 6, 7, 8, 9, 1, 2

for(let k = 0; k < 2; k++){
 if ( k > 0 ) {
 break;
 }
 for(let i = 0; i < len; i++) {
 if( arr[i] > 5 ) {
 break;
 }
 console.log(arr[i])
 }
}
结果:1, 2, 3, 4, 5

for(let k = 0; k < 2; k++){
 if ( k < 1 ) {
 break;
 }
 for(let i = 0; i < len; i++) {
 if( arr[i] > 5 ) {
 break;
 }
 console.log(arr[i])
 }
}
结果:空

小结:所谓就近原则,就是只影响包含它的最近的循环,只能受父亲,不能受爷爷,也不受儿子的影响,也可以说是解耦的。也常用语switch(n){ case 1: alert(1); break; default: alert(2); }中。

2)return

特点:只能出现在函数体内,用来终止整个函数的执行并返回想要返回值。

for(let i = 0; i < len; i++){
 if ( arr[i] > 5 ) {
 return false; // 只能出现在函数体内!!!
 }
 console.log(arr[i])
}
// 语法直接报错,无任何输出:
Uncaught SyntaxError: Illegal return statement

function func() {
 for(let i = 0; i < len; i++){
 if ( arr[i] > 5 ) {
 return 888;
 }
 console.log(arr[i])
 }
}
func();
结果:1, 2, 3, 4, 5, 888

小结: 只能用于函数体内,用以终止整个函数的执行。

总结:

1)使用环境,是否必须在函数体中使用;

2)终止范围,一条循环 or 整个循环 or 整个函数;

3) 就近原则

点关注,不迷路~

同时,便于查看历史文章。

家好,html模板的判断语句和Python里的写法是一样的,只不过每一行需要包裹在花括号和百分号里。

·从视图函数里传递一个名称为user的数据,user变量的值输入小铁,在html文件里判断。如果user返回了数据显示欢迎你小铁,否则如果没有显示数据显示请登录。

·最后用and if来闭合判断语句,运行Web服务,在浏览器里查看效果。因为user这个变量是有数据的,所以前端显示的欢迎您小铁。将user变量的值改成无,回到浏览器查看效果,这个时候浏览器显示的是请登录。

这就是html模板文件里if判断语句的使用方法。