alert()方法是如何阻塞JS的

寫了個表單钱磅,其中有個這樣的設(shè)定:

輸入密碼,如果密碼長度低于6位似枕,則輸入框顏色變黃盖淡,且彈出提醒“密碼長度不低于6位”。

我把這部分的代碼拎出來菠净,如下:

<html>
<head>
    <meta charset="utf-8">
    <title>alert問題</title>
    <style type="text/css">
        .bg {
            background-color: yellow;
        }
    </style>
</head>
<body>
    <input type="text" id="pwd">
    <input type="submit" id="btn" value="登錄">
    <script type="text/javascript">
        var btn = document.getElementById('btn');
        btn.onclick = function(){
            var pwd = document.getElementById('pwd');
            if (pwd.value.length < 6) {
                pwd.className = "bg";
                alert("密碼長度不低于6位");
            }
        }
    </script>
</body>
</html>

然而禁舷,在實際執(zhí)行的時候,卻發(fā)現(xiàn)一個現(xiàn)象:

微信截圖_20180425200122.png

先彈出alert對話框毅往,此時文本框并未變成黃色牵咙,點一下“確定”,文本框才變成黃色攀唯。

我們知道洁桌,JS是單線程的,alert()會阻塞JS繼續(xù)執(zhí)行侯嘀。

但是另凌,問題在于,“pwd.className = "bg";”在“alert("密碼長度不低于6位");”之前執(zhí)行戒幔,為什么還會被alert()阻塞呢吠谢?

有沒有可能是這樣:雖然pwd.className已經(jīng)被設(shè)置成了“bg”,但是CSS此時并沒有被加載诗茎,所以文本框仍然沒有變色工坊。JS繼續(xù)執(zhí)行,然后被alert()阻塞敢订。

為了驗證這個想法王污,我只需要在alert()前用console.log打印一下pwd,如果console里能出現(xiàn)pwd這個對象楚午,即便是文本框沒變色昭齐,仍然可以說明是按順序執(zhí)行的(這里我犯了一個錯,但是這個錯引出了有趣的東西)矾柜,于是循環(huán)體就變成:

pwd.className = "bg";
console.log(pwd);
alert("密碼長度不低于6位");

執(zhí)行一下試試阱驾,結(jié)果出乎意料,仍然是先彈出alert()對話框:

2.png

點完確定按鈕之后怪蔑,才同時出現(xiàn)pwd這個對象的內(nèi)容和黃色文本框啊易。

3.png

即便是不考慮CSS加載的問題,console.log(pwd);仍然沒有在alert()之前出結(jié)果饮睬。

很費解。篮奄。

猜想捆愁,由于alert()會阻塞js割去,給alert加個setTimeout試試:如果優(yōu)先執(zhí)行alert(),那么無論多少毫秒之后昼丑,都得alert()執(zhí)行完才能執(zhí)行console.log(pwd)呻逆。

pwd.className = "bg";
console.log(pwd);
setTimeout("alert('密碼長度不低于6位');", 100);

這段setTimeout代碼的意思是,100毫秒后執(zhí)行

"alert('密碼長度不低于6位');"

有趣的是菩帝,這次是console.log講pwd打印出來咖城,同時文本框變黃了,再彈出alert對話框呼奢。

4.png

也就是說宜雀,瀏覽器的確是按順序執(zhí)行的,并不是先運行alert()然后再去執(zhí)行前面的語句握础。

那為什么在之前的操作中辐董,出現(xiàn)了先alert()的情況呢?

答案可能就在setTimeout延后的時間里禀综。將這句代碼的時間改成1ms:

setTimeout("alert('密碼長度不低于6位');", 1);

果然又出現(xiàn)了先彈出alert()對話框并阻塞的情況简烘。我們可以推斷,其實此時瀏覽器已經(jīng)執(zhí)行過了修改className和打印pwd的操作定枷,僅僅過了1毫秒還沒有生效孤澎,js開始執(zhí)行alert(),然后就阻塞了欠窒。這也可以解釋設(shè)置成100毫秒就沒問題覆旭。

那瀏覽器多久可以設(shè)置好這兩項操作呢?

我試著在二分法在1-100ms之間找臨界點,發(fā)現(xiàn)我的瀏覽器在7毫秒的時候會先彈出alert再打印pwd窿给,而8毫米就可以先打印pwd再彈出alert组橄。

換句話說,瀏覽器需要8毫秒的時間茶敏,獲取到pwd對象,并將該對象轉(zhuǎn)化成字符串缚俏,在console里打印出來——其實也挺久的惊搏。

這里其實是我犯下的一個小錯誤,循環(huán)體里第一句“pwd.className = "bg";”忧换,其實后面更應(yīng)該用console.log()打印pwd.className而不是pwd本身恬惯。當然也正是因為這個疏忽,讓我發(fā)現(xiàn)了一些規(guī)律亚茬。

試一下:

pwd.className = "bg";
console.log(pwd.className);
setTimeout("alert('密碼長度不低于6位');", 1);

果然酪耳,瀏覽器花了1毫秒就獲取到了pwd的className。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市碗暗,隨后出現(xiàn)的幾起案子颈将,更是在濱河造成了極大的恐慌,老刑警劉巖言疗,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件晴圾,死亡現(xiàn)場離奇詭異,居然都是意外死亡噪奄,警方通過查閱死者的電腦和手機死姚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來勤篮,“玉大人都毒,你說我怎么就攤上這事⌒鸾鳎” “怎么了温鸽?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長手负。 經(jīng)常有香客問我涤垫,道長,這世上最難降的妖魔是什么竟终? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任蝠猬,我火速辦了婚禮,結(jié)果婚禮上统捶,老公的妹妹穿的比我還像新娘榆芦。我一直安慰自己,他們只是感情好喘鸟,可當我...
    茶點故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布匆绣。 她就那樣靜靜地躺著,像睡著了一般什黑。 火紅的嫁衣襯著肌膚如雪崎淳。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天愕把,我揣著相機與錄音拣凹,去河邊找鬼。 笑死恨豁,一個胖子當著我的面吹牛嚣镜,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播橘蜜,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼菊匿,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起捧请,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤凡涩,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后疹蛉,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡力麸,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年可款,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片克蚂。...
    茶點故事閱讀 39,727評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡闺鲸,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出埃叭,到底是詐尸還是另有隱情摸恍,我是刑警寧澤,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布赤屋,位于F島的核電站立镶,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏类早。R本人自食惡果不足惜媚媒,卻給世界環(huán)境...
    茶點故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望涩僻。 院中可真熱鬧缭召,春花似錦、人聲如沸逆日。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽室抽。三九已至搪哪,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間狠半,已是汗流浹背噩死。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留神年,地道東北人已维。 一個月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像已日,于是被迫代替她去往敵國和親垛耳。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,619評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 工廠模式類似于現(xiàn)實生活中的工廠可以產(chǎn)生大量相似的商品,去做同樣的事情堂鲜,實現(xiàn)同樣的效果;這時候需要使用工廠模式栈雳。簡單...
    舟漁行舟閱讀 7,752評論 2 17
  • 我們經(jīng)常會碰到一些需要定時執(zhí)行的需求,比如輪播圖缔莲、延遲消失等哥纫,這時候我們就會用到 setTimeout 這個方法了...
    ac68882199a1閱讀 6,522評論 16 22
  • 計時器setTimeout是我們經(jīng)常會用到的,它用于在指定的毫秒數(shù)后調(diào)用函數(shù)或計算表達式痴奏。 語法:setTimeo...
    TGCode閱讀 880評論 0 8
  • 死在水里读拆,或者床上 蒙昧皓月擅憔,或者理想 散佚堅持,或者倔強 葉子青綠檐晕,終于泛黃 不懂是喜悅暑诸,還是感傷 日子青澀,終...
    漁人劫閱讀 322評論 0 3