你是不是開著控制臺進行測試的,剛剛用chrome測試了一下,如果開著控制臺并且控制臺取得了焦點,alert
不會立即阻塞正在運行的線程,得等到焦點從控制臺重新回到頁面才會發(fā)出alert
并阻塞線程;但如果在執(zhí)行alert
之后立即修改window.location.href
,此時控制臺又取得了焦點,則alert
不會立即阻塞線程,jvm轉(zhuǎn)而執(zhí)行下一個語句修改window.location.href
,而這將導(dǎo)致之前尚未發(fā)出的alert
被取消(我猜的)。
結(jié)論是,不要開著控制臺測試這段代碼。
以下是我的測試代碼:
setTimeout(() => $.ajax({
url: '/',
type: 'GET',
success: data => {
console.log('Before rua');
alert('Rua!');
console.log('After rua');
window.location.href += '#';
},
error: (...args) => console.log(...args)
}), 1000);
如果你在1秒內(nèi)沒有將焦點切回頁面,則alert
不會發(fā)出,且window.location.href
將被立刻修改;若你在1秒內(nèi)將焦點切回頁面,則alert
發(fā)出,且window.location.href
將會在你將alert
dismiss掉后被修改。
或者更簡單粗暴一點:
setTimeout(() => {
console.log('Before rua');
alert('Rua!');
console.log('After rua');
window.location.href += '#';
}, 1000);
同上,1秒內(nèi)切回頁面就能看到alert
,dismiss后window.location.href
才會被修改,反之alert
會被取消。
與上述代碼之對比:
setTimeout(() => {
console.log('Before rua');
alert('Rua!');
console.log('After rua');
// window.location.href += '#';
}, 1000);
這里只是發(fā)出一個alert
,并沒有修改window.location.href
,在控制臺輸入上述代碼并運行后等待一秒,看到控制臺輸出了“Before rua”和“After rua”,這時再將焦點切回頁面,才會看到一個alert
彈出。
綜上,我猜測alert
其實也可以是異步的——當(dāng)渲染進程檢測到當(dāng)前頁面沒有獲取到焦點時,比如被用戶最小化了,此時若頁面中嵌入的js試圖發(fā)出alert
,則渲染進程不會立刻彈出alert
,而是將請求放入一個隊列中(pending),等待下一次獲取焦點時再一一彈出。
補充一下,目前使用chrome測試的結(jié)果是只有在焦點被控制臺獲取時發(fā)出alert
,并且在alert
之后修改了window.location.href
(焦點仍在控制臺),才會把alert
直接取消掉。最小化瀏覽器的話瀏覽器會自動跳出來發(fā)出alert
。
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
北大青鳥中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團,成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達(dá)內(nèi)教育集團成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。