最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:懂视网 责编:小采 时间:2020-11-27 21:53:04
文档

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

JavaScript跳出循环的三种方法(break, return, continue):前言: 一位前端界的大神让我去思考的一个问题, 给了Big-man一段代码,如下: function Seriously(options) { // if called without 'new', make a new object and return that if(window === this !(this
推荐度:
导读JavaScript跳出循环的三种方法(break, return, continue):前言: 一位前端界的大神让我去思考的一个问题, 给了Big-man一段代码,如下: function Seriously(options) { // if called without 'new', make a new object and return that if(window === this !(this

前言:

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

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

    声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文档

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

    JavaScript跳出循环的三种方法(break, return, continue):前言: 一位前端界的大神让我去思考的一个问题, 给了Big-man一段代码,如下: function Seriously(options) { // if called without 'new', make a new object and return that if(window === this !(this
    推荐度:
    标签: js 循环 三种方法
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top