<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
        主站蜘蛛池模板: 中中文字幕亚洲无线码| 日本免费一本天堂在线| 日韩中文无码有码免费视频| 亚洲精品视频观看| 亚洲AV无码国产在丝袜线观看| 亚洲国产精品无码中文lv | 国产亚洲美女精品久久久| 久久水蜜桃亚洲AV无码精品| 青苹果乐园免费高清在线| 亚洲黑人嫩小videos| 99热在线精品免费播放6| 久久久无码精品亚洲日韩蜜桃 | 日韩亚洲一区二区三区| fc2免费人成在线| 久久精品夜色噜噜亚洲A∨| 污污视频网站免费观看| 日本xxwwxxww在线视频免费 | 亚洲狠狠色丁香婷婷综合| 在线观看无码的免费网站| 日韩亚洲产在线观看| 成年美女黄网站18禁免费| 亚洲精品V欧洲精品V日韩精品| 日亚毛片免费乱码不卡一区| 亚洲电影日韩精品| 国产免费黄色无码视频| 国产亚洲av片在线观看16女人| 国产特黄一级一片免费| 亚洲第一极品精品无码久久| 日韩精品极品视频在线观看免费| 亚洲综合日韩中文字幕v在线| 最近免费中文字幕高清大全| 亚洲精品动漫在线| 最近2019中文字幕mv免费看 | 亚洲中文字幕无码久久| 女人被男人桶得好爽免费视频 | 亚洲av永久无码精品网站| 久久午夜羞羞影院免费观看| 亚洲综合久久1区2区3区| 国产成人免费网站| 免费一级全黄少妇性色生活片| 亚洲伊人久久综合中文成人网 |