• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答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
    主站蜘蛛池模板: 久久国产热精品波多野结衣AV| 精品亚洲成a人片在线观看| 久久亚洲国产精品一区二区| 三级国产精品| 四虎在线精品视频一二区| 亚洲精品国产美女久久久| 国产精品乱码一区二区三区| 国产精品女同久久久久电影院| 国产精品区一区二区三在线播放| 精品9E精品视频在线观看| 国产香蕉国产精品偷在线| 国产欧美久久久精品| 久久国产亚洲精品无码| 无码精品人妻一区| 国产玖玖玖九九精品视频| 国产欧美久久久精品| 精品无码久久久久国产| 久久精品国产久精国产| 97久久精品国产精品青草| 亚洲欧美日韩久久精品| 久久精品国产一区二区三区| 91po国产在线精品免费观看| 大桥未久在线精品视频在线| 精品国产乱码一区二区三区| 中文字幕乱码中文乱码51精品| 久久久一本精品99久久精品88| 99re这里只有精品国产精品| 亚洲精品乱码久久久久久蜜桃图片| 99热这里只有精品在线| 日产欧美国产日韩精品| 性欧洲精品videos| 亚洲欧洲美洲无码精品VA| 午夜精品久久影院蜜桃 | 亚洲线精品一区二区三区| 国产精品毛片a∨一区二区三区| 精品一区二区三区东京热| 无码欧精品亚洲日韩一区| 亚洲精品无码高潮喷水在线| 一本一道精品欧美中文字幕| 亚欧洲精品在线视频免费观看| 亚洲精品在线观看视频|