JavaScript跳出循环的三种方法(break, return, continue)


Posted in Javascript onJuly 30, 2019

前言:

一位前端界的大神让我去思考的一个问题, 给了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的。

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
asp.net+js 实现无刷新上传解析csv文件的代码
May 17 Javascript
深入了解javascript中的prototype与继承
Apr 14 Javascript
jQuery设置指定网页元素宽度和高度的方法
Mar 25 Javascript
JS实现刷新父页面不弹出提示框的方法
Jun 22 Javascript
AngularJS ng-mousedown 指令
Aug 02 Javascript
Node.js对MongoDB数据库实现模糊查询的方法
May 03 Javascript
基于JS实现限时抢购倒计时间表代码
May 09 Javascript
js正则取值的结果数组调试方法
Oct 10 Javascript
GOJS+VUE实现流程图效果
Dec 01 Javascript
移动端如何用下拉刷新的方式实现上拉加载
Dec 10 Javascript
如何使用vue slot创建一个模态框的实例代码
May 24 Javascript
原生js+css实现tab切换功能
Sep 17 Javascript
8个有意思的JavaScript面试题
Jul 30 #Javascript
开源一个微信小程序仪表盘组件过程解析
Jul 30 #Javascript
原生js添加一个或多个类名的方法分析
Jul 30 #Javascript
vue2.0项目集成Cesium的实现方法
Jul 30 #Javascript
Koa从零搭建到Api实现项目的搭建方法
Jul 30 #Javascript
js实现的格式化数字和金额功能简单示例
Jul 30 #Javascript
JS实现点击发送验证码 xx秒后重新发送功能
Jul 30 #Javascript
You might like
解析php二分法查找数组是否包含某一元素
2013/05/23 PHP
PHP生成静态HTML页面最简单方法示例
2015/04/09 PHP
jQuery+PHP发布的内容进行无刷新分页(Fckeditor)
2015/10/22 PHP
php使用lua+redis实现限流,计数器模式,令牌桶模式
2019/04/04 PHP
php array_chunk()函数用法与注意事项
2019/07/12 PHP
php远程请求CURL实例教程(爬虫、保存登录状态)
2020/12/10 PHP
js输出列表实现代码
2010/09/12 Javascript
Dom 学习总结以及实例的使用介绍
2013/04/24 Javascript
js获取域名的方法
2015/01/27 Javascript
js添加千分位的实现代码(超简单)
2016/08/01 Javascript
JavaScript之WebSocket技术详解
2016/11/18 Javascript
详解Weex基于Vue2.0开发模板搭建
2017/03/20 Javascript
javascript少儿编程关于返回值的函数内容
2018/05/27 Javascript
JS前端面试必备——基本排序算法原理与实现方法详解【插入/选择/归并/冒泡/快速排序】
2020/02/24 Javascript
微信小程序仿通讯录功能
2020/04/09 Javascript
nuxt.js服务端渲染中axios和proxy代理的配置操作
2020/11/06 Javascript
Python实现的数据结构与算法之链表详解
2015/04/22 Python
使用PDB简单调试Python程序简明指南
2015/04/25 Python
python使用socket向客户端发送数据的方法
2015/04/29 Python
Python3使用requests发闪存的方法
2016/05/11 Python
详解Python中for循环是如何工作的
2017/06/30 Python
Python MD5加密实例详解
2017/08/02 Python
在python中pandas读文件,有中文字符的方法
2018/12/12 Python
Python数据可视化教程之Matplotlib实现各种图表实例
2019/01/13 Python
python 截取XML中bndbox的坐标中的图像,另存为jpg的实例
2020/03/10 Python
Python内置异常类型全面汇总
2020/05/28 Python
详解tf.device()指定tensorflow运行的GPU或CPU设备实现
2021/02/20 Python
解决TensorFlow训练模型及保存数量限制的问题
2021/03/03 Python
CSS3的transition和animation的用法实例介绍
2014/08/20 HTML / CSS
在html5的Canvas上绘制椭圆的几种方法总结
2013/01/07 HTML / CSS
毕业生医学检验求职信
2013/10/16 职场文书
污水厂厂长岗位职责
2014/01/04 职场文书
公司周年庆典邀请函
2014/01/12 职场文书
挂靠协议书
2015/01/27 职场文书
活动总结书怎么写
2015/05/11 职场文书
MySQL索引失效十种场景与优化方案
2023/05/08 MySQL