<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答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中if和switch,==和===詳解_javascript技巧

        來源:懂視網 責編:小采 時間:2020-11-27 21:41:08
        文檔

        javascript中if和switch,==和===詳解_javascript技巧

        javascript中if和switch,==和===詳解_javascript技巧:今天改插件BoxScroll的時候,因為if里面的條件判斷多于兩個,于是立馬想著改寫switch。改到一半,忽然記起來JSHint等代碼質量檢測工具中的一個要求,用===替換==,不用不可靠的強制轉型。然后忽然猜想,改成switch是不是會降低效率???switch里面的實際
        推薦度:
        導讀javascript中if和switch,==和===詳解_javascript技巧:今天改插件BoxScroll的時候,因為if里面的條件判斷多于兩個,于是立馬想著改寫switch。改到一半,忽然記起來JSHint等代碼質量檢測工具中的一個要求,用===替換==,不用不可靠的強制轉型。然后忽然猜想,改成switch是不是會降低效率???switch里面的實際
        今天改插件BoxScroll的時候,因為if里面的條件判斷多于兩個,于是立馬想著改寫switch。改到一半,忽然記起來JSHint等代碼質量檢測工具中的一個要求,用===替換==,不用不可靠的強制轉型。然后忽然猜想,改成switch是不是會降低效率啊?switch里面的實際判斷是==還是===?

        有了想法,趕緊舉個栗子,好一口吃掉:

        最后控制臺顯示的是===,看來可以放心的用。找了下以前的學習筆記,嗯,高三里面確實也說switch判斷是全等運算符,因此不會發生類型轉換。這里小結一下

          1.if和switch

        if 是用得最多的,沒什么太多好說。值得注意的一點是:if 其實和 || 很像,如果if (conditionA){} else {} 中的conditionA為true,然后它執行完else之前的代碼塊后就看都不會看else里面的代碼。和 || 前面為true的時候后面會被忽略一樣,即便里面有再多的錯誤。基于這個性質,當然把可能用得最多的代碼塊放在前面,減少判斷次數。另一方面,如果有很多的 if 判斷,而且可能執行的次數分布比較均勻,那么后面的判斷語句每次都要把前面的判斷一個一個執行完,不利于優化。比較好的做法是將一層判斷語句變成兩層判斷語句,如

        變為

          雖然前面的每個判斷都多加了一次,但是后面的判斷就都減少了(4-1)*n次,還是滿賺的。忽然覺得這種方式和嵌套循環有點像,循環次數少的放在外面有助于性能優化,如何分成兩層甚至多層就要看具體情況了。

          switch是 if 最親密的戰友,每次 if 忙不過來的時候就過來搭把手。switch和 if 互轉估計沒什么好說的,而且switch和if一樣,都是順序從上往下執行判斷的,有所不同的是 if 中的else在switch里面可不管用,它有自己的小弟:break。如果沒有遇到break,switch會繼續往下執行,如

          最后控制臺顯示 2,3,no break 。其實也蠻好理解,break是提示程序跳出內部執行體到下一個case 判斷,如果沒有了,相當于 if(condition){A}{B},沒有了else,A和B當然都要執行啦。還有兩個小tip,一是switch和case中可以寫任何表達式,如

          實際上的比較是 (A+B)===(a*b)和(A+B)===(a/b+c)。二是switch有一種特殊的用法,如

          此時switch中的每一個case都會按照順序判斷執行。至于switch(false)?并沒有什么卵用。

          2.==與===

          一句話搞定,除了在比較之前不轉換操作數之外,全等和不全等操作符與相等和不相等操作符并沒有什么不同。

          最經典的案例

          下面的顯示true的原因其實和string類型不可變是分不開的。表面看上去b只是簡單的拼接一個字符串,但實際上它已經和原來的b沒有關系。每一個字符串都存在內存池中特定的地方,當b="AB"+"C"執行完的時候,字符串AB和C就已經被銷毀,而b指向內存池中ABC的位置。由于在指向前在內存池中發現了字符串ABC(因為a引用著它,所以存在),所以b就和a指向同一塊區域,全等判斷相等。如果在b之前沒有任何變量指向字符串ABC,那么內存池中沒有,就會在里面劃一塊地方給ABC,并將b指向ABC。

          附以前的總結圖兩張:

        以上所述就是本文的全部內容了,希望大家能夠喜歡。

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        javascript中if和switch,==和===詳解_javascript技巧

        javascript中if和switch,==和===詳解_javascript技巧:今天改插件BoxScroll的時候,因為if里面的條件判斷多于兩個,于是立馬想著改寫switch。改到一半,忽然記起來JSHint等代碼質量檢測工具中的一個要求,用===替換==,不用不可靠的強制轉型。然后忽然猜想,改成switch是不是會降低效率啊?switch里面的實際
        推薦度:
        標簽: switch js sw
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 一个人看的在线免费视频| 国产人在线成免费视频| 免费大片黄在线观看yw| 欧美好看的免费电影在线观看| 国产精品久久久久久亚洲影视 | 亚洲精品国偷自产在线| 亚洲精品成a人在线观看☆| 在线观看的免费网站| 亚洲毛片免费观看| 51在线视频免费观看视频| 好吊妞视频免费视频| jjzz亚洲亚洲女人| 久久久久久亚洲av成人无码国产| 亚洲国产精品国产自在在线| 亚洲 欧洲 视频 伦小说| 牛牛在线精品观看免费正| 午夜不卡久久精品无码免费| 亚洲一区二区三区在线观看精品中文 | 777亚洲精品乱码久久久久久 | 亚洲国产中文字幕在线观看| 亚洲国产一区二区a毛片| 久久亚洲精品国产精品婷婷| 日本zzzzwww大片免费| 99久久99久久精品免费观看| 免费激情视频网站| 亚洲熟女一区二区三区| 国产成人精品免费视频大全| 97免费人妻无码视频| 亚洲国产精品成人AV无码久久综合影院 | 人人狠狠综合久久亚洲88| 亚洲熟妇丰满xxxxx| 99精品在线免费观看| 亚洲精品电影天堂网| 成人奭片免费观看| 久久久久久亚洲av无码蜜芽| 国产一级淫片视频免费看| 亚洲精品视频免费看| 欧美日韩国产免费一区二区三区| 亚洲男人天堂av| 一二三四在线观看免费高清中文在线观看 | 亚洲人成影院午夜网站|