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写了一个清除“logo1_.exe”的杀毒工具(可扫描目录)
Feb 09 Javascript
jquery可见性过滤选择器使用示例
Jun 24 Javascript
纯Javascript实现Windows 8 Metro风格实现
Oct 15 Javascript
页面实时更新时间的JS实例代码
Dec 18 Javascript
导入extjs、jquery 文件时$使用冲突问题解决方法
Jan 14 Javascript
jquery 按键盘上的enter事件
May 11 Javascript
jquery比较简洁的软键盘特效实现方法
Mar 19 Javascript
JQuery控制radio选中和不选中方法总结
Apr 15 Javascript
JS获取鼠标选中的文字
Aug 10 Javascript
Vue-Router进阶之滚动行为详解
Sep 13 Javascript
Vue如何基于es6导入外部js文件
May 15 Javascript
小程序组件传值和引入sass的方法(使用vant Weapp组件库)
Nov 24 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动态创建Web站点的方法
2011/08/14 PHP
8个必备的PHP功能开发
2015/10/02 PHP
判断脚本加载是否完成的方法
2009/05/26 Javascript
JavaScript Event事件学习第一章 Event介绍
2010/02/07 Javascript
js replace替换所有匹配的字符串
2014/02/13 Javascript
javascript实现拖放效果
2015/12/16 Javascript
jQuery实现模仿微博下拉滚动条加载数据效果
2015/12/25 Javascript
基于JavaScript实现瀑布流效果(循环渐近)
2016/01/27 Javascript
javascript点击按钮实现隐藏显示切换效果
2016/02/03 Javascript
JS获取地址栏参数的两种方法(简单实用)
2016/06/14 Javascript
Angularjs 实现一个幻灯片示例代码
2016/09/08 Javascript
JavaScript常用正则验证函数实例小结【年龄,数字,Email,手机,URL,日期等】
2017/01/23 Javascript
vue.js简单配置axios的方法详解
2017/12/13 Javascript
JavaScript刷新页面的几种方法总结
2019/03/28 Javascript
通过JQuery,JQueryUI和Jsplumb实现拖拽模块
2019/06/18 jQuery
小程序双头slider选择器的实现示例
2020/03/31 Javascript
Python实现二叉堆
2016/02/03 Python
Python设置默认编码为utf8的方法
2016/07/01 Python
Python 硬币兑换问题
2019/07/29 Python
Python使用uuid库生成唯一标识ID
2020/02/12 Python
Python+Appium实现自动化测试的使用步骤
2020/03/24 Python
浅谈在JupyterNotebook下导入自己的模块的问题
2020/04/16 Python
美国在线珠宝商店:SZUL
2017/02/11 全球购物
固特异美国在线轮胎店:Goodyear Tire
2019/02/23 全球购物
波兰珠宝品牌:YES
2019/08/09 全球购物
美容师的职业规划书
2013/12/27 职场文书
关爱残疾人演讲稿
2014/05/24 职场文书
2014国庆节幼儿园亲子活动方案
2014/09/16 职场文书
个人遵守党的政治纪律情况对照检查材料
2014/09/26 职场文书
四风问题个人对照检查剖析材料
2014/09/27 职场文书
优秀教师个人总结
2015/02/11 职场文书
和领导吃饭祝酒词
2015/08/11 职场文书
老舍《猫》教学反思
2016/02/17 职场文书
python基础学习之递归函数知识总结
2021/05/26 Python
Python OpenCV 图像平移的实现示例
2021/06/04 Python
python模块与C和C++动态库相互调用实现过程示例
2021/11/02 Python