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 相关文章推荐
javascript firefox不显示本地预览图片问题的解决方法
Nov 12 Javascript
Prototype源码浅析 String部分(一)之有关indexOf优化
Jan 15 Javascript
js+xml生成级联下拉框代码
Jul 24 Javascript
javascript + jquery实现定时修改文章标题
Mar 19 Javascript
Javascript判断文件是否存在(客户端/服务器端)
Sep 16 Javascript
jQuery使用attr()方法同时设置多个属性值用法实例
Mar 26 Javascript
AngularJS入门教程之AngularJS模型
Apr 18 Javascript
微信小程序 window_x64环境搭建
Sep 30 Javascript
JS表单验证方法实例小结【电话、身份证号、Email、中文、特殊字符、身份证号等】
Feb 14 Javascript
基于Vue2x的图片预览插件的示例代码
May 14 Javascript
Vue组件创建和传值的方法
Aug 17 Javascript
3分钟了解vue数据劫持的原理实现
May 01 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
thinkphp配置连接数据库技巧
2014/12/02 PHP
初识laravel5
2015/03/02 PHP
php+jQuery递归调用POST循环请求示例
2016/10/14 PHP
thinkPHP自动验证机制详解
2016/12/05 PHP
用JQuery 实现的自定义对话框
2007/03/24 Javascript
js中的异常处理try...catch使用介绍
2013/09/21 Javascript
jQuery之DOM对象和jQuery对象的转换与区别分析
2015/01/08 Javascript
CSS+JS实现点击文字弹出定时自动关闭DIV层菜单的方法
2015/05/12 Javascript
jQuery 1.9.1源码分析系列(十四)之常用jQuery工具
2015/12/02 Javascript
JavaScript构造函数详解
2015/12/27 Javascript
使用jquery.form.js实现图片上传的方法
2016/05/05 Javascript
JavaScript中的await/async的作用和用法
2016/10/31 Javascript
js 获取本地文件及目录的方法(推荐)
2016/11/10 Javascript
详解使用angular框架离线你的应用(pwa指南)
2019/01/31 Javascript
微信小程序HTTP接口请求封装的实现
2019/02/21 Javascript
微信小程序实现批量倒计时功能
2020/11/01 Javascript
vue集成chart.js的实现方法
2019/08/20 Javascript
JS写滑稽笑脸运动效果
2020/05/28 Javascript
在js文件中引入(调用)另一个js文件的三种方法
2020/09/11 Javascript
让Vue响应Map或Set的变化操作
2020/11/11 Javascript
Python程序员面试题 你必须提前准备!
2018/01/16 Python
浅析Windows 嵌入python解释器的过程
2019/07/26 Python
python GUI库图形界面开发之PyQt5信号与槽多窗口数据传递详细使用方法与实例
2020/03/08 Python
Python中logging日志记录到文件及自动分割的操作代码
2020/08/05 Python
python3字符串输出常见面试题总结
2020/12/01 Python
西班牙英格列斯百货法国官网:El Corte Inglés法国
2017/07/09 全球购物
英国最大的在线时尚眼镜店:Eyewearbrands
2019/03/12 全球购物
新东网科技Java笔试题
2012/07/13 面试题
岗位职责范本
2013/11/23 职场文书
英语专业毕业生自荐信范文
2013/12/31 职场文书
大型演出策划方案
2014/05/28 职场文书
通报表扬范文
2015/01/17 职场文书
2019森林防火宣传标语大全!
2019/07/03 职场文书
劳务派遣管理制度(样本)
2019/08/23 职场文书
php 获取音视频时长,PHP 利用getid3 获取音频文件时长等数据
2021/04/01 PHP
Python人工智能之混合高斯模型运动目标检测详解分析
2021/11/07 Python