摘要:由于始終沒有還原阻塞時的情形,無法截圖。寫模擬場景,由于當時的場景是外鏈是加載阻塞,而不是執(zhí)行阻塞,暫時沒有有效模擬。但是可以確定的是,使用或可以有效解決,外鏈阻塞內(nèi)部執(zhí)行的問題。
由于始終沒有還原阻塞時的情形,無法截圖。在正常情況下,是無法區(qū)別是否使用defer的區(qū)別的。后續(xù)看一下是否能模擬場景。
寫demo模擬場景,由于當時的場景是外鏈是js加載阻塞,而不是js執(zhí)行阻塞,暫時沒有有效模擬。
但是可以確定的是,使用defer或async可以有效解決,外鏈js阻塞內(nèi)部js執(zhí)行的問題。
Demo詳情:
ndex1里面是一個耗時一秒鐘的操作
結(jié)果
如將index1.js加上defer后
發(fā)現(xiàn),耗時的index1,沒有阻塞后續(xù)的index2和內(nèi)嵌js2執(zhí)行
假如將index1.js加上async
可發(fā)現(xiàn),不但沒有阻塞后續(xù)的index2和內(nèi)嵌js2執(zhí)行,DOMContentLoad時間也提前了
假如index1和index2都async了
可發(fā)現(xiàn),內(nèi)嵌的js1和js2,提前,外接index1,和index2順序執(zhí)行,index1阻塞了index2
假如耗時的index1 async, 后置位index2 defer
可發(fā)現(xiàn),內(nèi)嵌的js1和js2,提前, index1不阻塞了index2
假如耗時的index1 defer, 后置位index2 async
可發(fā)現(xiàn),內(nèi)嵌的js1和js2,提前, index1阻塞了index2,DOMContentLoad時間滯后
結(jié)論:
1.使用defer, async異步加載,可以使內(nèi)部的js不被阻塞
2.使用defer屬性的標簽,永遠在DOMContentLoaded事件之前執(zhí)行完成。
3.defer可以阻塞async的執(zhí)行,雖然兩個標簽都是異步下載的
回到項目中:
一站式是React渲染,React的js腳本執(zhí)行一定是在DOMContentLoaded時間之前
我發(fā)現(xiàn)給機器人sdk加上defer之后 first paint 仍然是在DOMContentLoad之后,那我猜想,defer并不能使DOMContentLoad提前,會不會不能解決這個問題
然后我找了個外網(wǎng)React CDN的script標簽來模擬這個超時加載sdk的場景,發(fā)現(xiàn)首屏時間大大延長
延長時間基本等于js加載時間,2.63s, 而且首次渲染在DOMContentLoad之前,首屏時間沒有截全,但是看看下面這個圖你就明白了,肯定在2S以上,肯定是未加載的js影響了頁面的渲染
然后給其加上defer屬性,基本影響就小很多了,
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/100401.html
摘要:下面我們撇開網(wǎng)絡方面的優(yōu)化,只分析靜態(tài)資源方面的優(yōu)化。不過,也會阻止的構(gòu)建和延緩網(wǎng)頁渲染。未優(yōu)化正常加載優(yōu)化后異步加載根據(jù)上面的分析,我們可以清楚的認識到,非必要優(yōu)先加載的,選擇異步加載是最優(yōu)選擇。 為什么做優(yōu)化 經(jīng)典問題:白屏時間過長,用戶體驗差產(chǎn)生的原因:網(wǎng)絡問題、關鍵渲染路徑(CRP)問題 怎么做優(yōu)化 如何做好優(yōu)化呢,網(wǎng)上隨便一搜,就有很多優(yōu)化總結(jié),無非就是網(wǎng)絡優(yōu)化、靜態(tài)資源(h...
摘要:下面我們撇開網(wǎng)絡方面的優(yōu)化,只分析靜態(tài)資源方面的優(yōu)化。不過,也會阻止的構(gòu)建和延緩網(wǎng)頁渲染。未優(yōu)化正常加載優(yōu)化后異步加載根據(jù)上面的分析,我們可以清楚的認識到,非必要優(yōu)先加載的,選擇異步加載是最優(yōu)選擇。 為什么做優(yōu)化 經(jīng)典問題:白屏時間過長,用戶體驗差產(chǎn)生的原因:網(wǎng)絡問題、關鍵渲染路徑(CRP)問題 怎么做優(yōu)化 如何做好優(yōu)化呢,網(wǎng)上隨便一搜,就有很多優(yōu)化總結(jié),無非就是網(wǎng)絡優(yōu)化、靜態(tài)資源(h...
摘要:下面我們撇開網(wǎng)絡方面的優(yōu)化,只分析靜態(tài)資源方面的優(yōu)化。不過,也會阻止的構(gòu)建和延緩網(wǎng)頁渲染。未優(yōu)化正常加載優(yōu)化后異步加載根據(jù)上面的分析,我們可以清楚的認識到,非必要優(yōu)先加載的,選擇異步加載是最優(yōu)選擇。 為什么做優(yōu)化 經(jīng)典問題:白屏時間過長,用戶體驗差產(chǎn)生的原因:網(wǎng)絡問題、關鍵渲染路徑(CRP)問題 怎么做優(yōu)化 如何做好優(yōu)化呢,網(wǎng)上隨便一搜,就有很多優(yōu)化總結(jié),無非就是網(wǎng)絡優(yōu)化、靜態(tài)資源(h...
閱讀 3755·2021-11-22 13:52
閱讀 3628·2019-12-27 12:20
閱讀 2401·2019-08-30 15:55
閱讀 2154·2019-08-30 15:44
閱讀 2272·2019-08-30 13:16
閱讀 585·2019-08-28 18:19
閱讀 1893·2019-08-26 11:58
閱讀 3447·2019-08-26 11:47