欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS script腳本中async和defer區(qū)別詳解

 更新時(shí)間:2020年06月24日 11:50:21   作者:聽風(fēng)是風(fēng)  
這篇文章主要介紹了JS script腳本中async和defer區(qū)別詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

一 引言

代碼如下

<script src="https://www.google.com/recaptcha/api.js" async defer></script>

可以看到在script標(biāo)簽中,存在async與defer兩個(gè)屬性,首先這兩個(gè)屬性并共存,說直白點(diǎn),你一個(gè)都不加,或者加兩個(gè)屬性其一,腳本加載規(guī)則都會(huì)不同,這點(diǎn)我在之前確實(shí)沒仔細(xì)了解過,導(dǎo)致我在實(shí)際開發(fā)中遇到了這樣一個(gè)問題:

我在同一個(gè)頁面需要引用2個(gè)script腳本,大致如下:

<script src="https://www.google.com/recaptcha/api.js"></script>
<script src="demo.js"></script>

注意,兩個(gè)script腳本都沒有添加async與defer屬性,demo.js中包含了谷歌人機(jī)驗(yàn)證的初始化程序,正常來說一定得先加載必要的資源,這樣我的驗(yàn)證碼才能初始化成功,這就像使用jQuery得先引用jQuery.js是一個(gè)道理。

但事實(shí)上,因?yàn)橥饩W(wǎng)的問題,api.js引用雖然在前面,但下載并不穩(wěn)定,有時(shí)候會(huì)出現(xiàn)下載反而比demo.js更晚的情況,這就導(dǎo)致demo.js中的初始化報(bào)錯(cuò),怎么辦呢?這就得async與defer出場(chǎng)了,我們先來了解它們的區(qū)別。

二 屬性async、defer與不加的區(qū)別

1 不加屬性

引用script腳本,最常見的就是直接引用,不加其它屬性,這種情況瀏覽器會(huì)立即下載并執(zhí)行指定的腳本,一氣呵成,腳本不執(zhí)行完畢,后面的DOM加載全部給我候著,如下圖:

2 屬性async

了解ajax的同學(xué)對(duì)于async這個(gè)詞一定不陌生,它表示異步,如果script腳本添加了此屬性,瀏覽器會(huì)異步下載后立刻同步執(zhí)行腳本。

說通俗點(diǎn),腳本下載是異步行為,下載過程中并不影響DOM加載,但一旦腳本下載完畢就會(huì)立刻同步執(zhí)行腳本,此時(shí)DOM加載還是得給我等著。如下圖:

3 屬性defer

與async一樣屬于異步下載腳本,但不同的地方是,腳本下載完成后并不會(huì)立刻執(zhí)行,而是等到DOM解析完成才會(huì)執(zhí)行腳本,相比async的粗暴,defer明顯更加實(shí)用。加載順序如下圖:

現(xiàn)在我們知道了腳本屬性async、defer以及不加的區(qū)別,回到文章開始的問題,我希望api.js一定在demo.js之前加載完成,不管需要等多久,所以我們可以這樣修改:

<script src="https://www.google.com/recaptcha/api.js" async></script>
<script src="demo.js" defer></script>

那么到這里本文正式結(jié)束。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論