溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

javascript中的defer是什么

發(fā)布時間:2021-07-21 16:31:06 來源:億速云 閱讀:160 作者:chen 欄目:web開發(fā)

這篇文章主要講解了“javascript中的defer是什么”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“javascript中的defer是什么”吧!

defer告訴瀏覽器Script段包含了無需立即執(zhí)行的代碼,并且與SRC屬性聯(lián)合使用,它還可以使這些腳本在后臺被下載,前臺的內(nèi)容則正常顯示給用戶;語法“<script defer>js代碼</script>”。

本教程操作環(huán)境:windows7系統(tǒng)、javascript1.8.5版、Dell G3電腦。

很多人都已經(jīng)把 Javascript的用的爐火純青了,但見到defer未必就知道他是做什么用的;很多人也都遇到過這樣的問題,需要直接執(zhí)行別且操作DOM對象的js 總是報找不到對象的錯誤,原因大家也都知道就是頁面還有沒有加載完畢,js的操作對象還在下載中。但很多人都不知道,添加defer標(biāo)簽就能輕而易舉的解決這個問題。

<script src="../CGI-bin/delscript.js" defer></script>

中的defer作用是文檔加載完畢了再執(zhí)行腳本,這樣回避免找不到對象的問題---有點(diǎn)問題

<button id="myButton" onclick="alert('ok')">test</button>
<script>
myButton.click();
</script>

<script>
myButton.click();
</script>
<button id="myButton" onclick="alert('ok')">test</button>

<script defer>
function document.body.onload() {
alert(document.body.offsetHeight);
}
</script>

加上 defer 等于在頁面完全在入后再執(zhí)行,相當(dāng)于 window.onload ,但應(yīng)用上比 window.onload 更靈活!

defer是腳本程序強(qiáng)大功能中的一個“無名英雄”。它告訴瀏覽器Script段包含了無需立即執(zhí)行的代碼,并且,與SRC屬性聯(lián)合使用,它還可以使這些腳本在后臺被下載,前臺的內(nèi)容則正常顯示給用戶。

--但是 文檔加載完畢了再執(zhí)行腳本

請注意兩點(diǎn):

1、不要在defer型的腳本程序段中調(diào)用document.write命令,因為document.write將產(chǎn)生直接輸出效果。

2、而且,不要在defer型腳本程序段中包括任何立即執(zhí)行腳本要使用的全局變量或者函數(shù)。

一個常用的優(yōu)化性能的方法是:當(dāng)腳本不需要立即運(yùn)行時,在<SCRIPT>標(biāo)簽中設(shè)置“defer”屬性。 (立即腳本沒有被包含在一個function塊中,因此會在加載過程中執(zhí)行。) 設(shè)置“defer”屬性后,IE就不必等待該腳本裝載和執(zhí)行完畢。這樣頁面加載會更快。一般來說,這也表明立即腳本最好放在function塊中,并在 document或者body對象的onload 句柄中處理該函數(shù)。在有一些腳本需要依賴用戶操作而執(zhí)行時----例如點(diǎn)擊按鈕,或者移動鼠標(biāo)到某個區(qū)域----使用該屬性非常有用。但當(dāng)有一些腳本需要在頁面加載過程中或加載完成后執(zhí)行,使用defer屬性得到的好處就不太大。

script中的defer屬性默認(rèn)情況下是false的。按照DHTML編程寶典中的描述,對于Defer屬性是這樣寫的:

Using the attribute at design time can improve the download performance of a page because the browser does not need to parse and execute the script and can continue downloading and parsing the page instead.

也就是說:如果是編寫腳本的時候加入defer屬性,那么瀏覽器在下載腳本的時候就不必立即對其進(jìn)行處理,而是繼續(xù)對頁面進(jìn)行下載和解析,這樣會提高下載的性能。

這樣的情況有很多種。比如你定義了很多javascript變量,或者在引用文件(.inc)中寫了很多的腳本需要處理,那不妨在這些腳本中加入defer屬性,對性能的提高肯定有所幫助。

舉例如下:

<script language="javascript" defer>
var object = new Object();
....
</script>

因為defer屬性默認(rèn)是為false的,那么在這里

<script language="javascript" defer>

顯式聲明defer屬性后等同于

<script language="javascript" defer=true>

聲明了defer屬性之后,需要判斷是否有別的變量引用了defer腳本塊中的變量,否則的話會導(dǎo)致腳本錯誤的產(chǎn)生。

感謝各位的閱讀,以上就是“javascript中的defer是什么”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對javascript中的defer是什么這一問題有了更深刻的體會,具體使用情況還需要大家實(shí)踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI