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 eval函数深入认识
Feb 21 Javascript
仿jQuery的siblings效果的js代码
Aug 09 Javascript
js计算字符串长度包含的中文是utf8格式
Oct 15 Javascript
使用js如何实现全选与全不选
Dec 30 Javascript
JavaScript中Boolean对象的属性解析
Oct 21 Javascript
原生js配合cookie制作保存路径的拖拽
Dec 29 Javascript
Jquery 自定义事件实现发布/订阅的简单实例
Jun 12 Javascript
bootstrap滚动监控器使用方法解析
Jan 13 Javascript
详解vue事件对象、冒泡、阻止默认行为
Mar 20 Javascript
Vue2.x中的父子组件相互通信的实现方法
May 02 Javascript
jQuery 开发之EasyUI 添加数据的实例
Sep 26 jQuery
微信小程序实现slideUp、slideDown滑动效果及点击空白隐藏功能示例
Dec 11 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另类上传图片的方法(PHP用Socket上传图片)
2013/10/30 PHP
ThinkPHP多语言支持与多模板支持概述
2014/08/22 PHP
使用PHP和JavaScript判断请求是否来自微信内浏览器
2015/08/18 PHP
thinkPHP批量删除的实现方法分析
2016/11/09 PHP
createElement动态创建HTML对象脚本代码
2008/11/24 Javascript
defer属性导致引用JQuery的页面报“浏览器无法打开网站xxx,操作被中止”错误的解决方法
2010/04/27 Javascript
基于jquery库的tab新形式使用
2012/11/16 Javascript
js返回上一页并刷新代码整理
2012/12/21 Javascript
onkeyup,onkeydown和onkeypress的区别介绍
2013/10/21 Javascript
jQuery 和 CSS 的文本特效插件集锦
2014/12/12 Javascript
jQuery Uploadify 上传插件出现Http Error 302 错误的解决办法
2015/12/12 Javascript
React-intl 实现多语言的示例代码
2017/11/03 Javascript
javascript 通过键名获取键盘的keyCode方法
2017/12/31 Javascript
vue-cli实现多页面多路由的示例代码
2018/01/30 Javascript
小程序和web画三角形实现解析
2019/09/02 Javascript
js 数组当前行添加数据方法详解
2020/07/28 Javascript
JavaScript 如何计算文本的行数的实现
2020/09/14 Javascript
Python字符串中查找子串小技巧
2015/04/10 Python
用Python写冒泡排序代码
2016/04/12 Python
python 矩阵增加一行或一列的实例
2018/04/04 Python
Python 实现还原已撤回的微信消息
2019/06/18 Python
基于Python解密仿射密码
2019/10/21 Python
python实现连续变量最优分箱详解--CART算法
2019/11/22 Python
python groupby 函数 as_index详解
2019/12/16 Python
Pytorch使用MNIST数据集实现基础GAN和DCGAN详解
2020/01/10 Python
英国复古皮包品牌:Beara Beara
2018/07/18 全球购物
英超联赛的首选足球:Mitre足球
2019/05/06 全球购物
YBF Beauty官网:美丽挚友,美国知名彩妆品牌
2020/11/22 全球购物
SQL Server 2000数据库的文件有哪些,分别进行描述。
2015/11/09 面试题
如何填写个人简历自我评价
2013/12/10 职场文书
简历自我评价怎么写呢?
2014/01/06 职场文书
家长对孩子的评语
2014/04/18 职场文书
安康杯竞赛活动总结
2014/05/05 职场文书
2015年女生节活动总结
2015/02/27 职场文书
辞职信标准格式
2015/02/27 职场文书
决心书格式及范文
2019/06/24 职场文书