DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript基礎知識 >> <script defer> defer 是什麼意思
<script defer> defer 是什麼意思
編輯:JavaScript基礎知識     
程序下載完後再進行解析和執行。
文檔上說defer中的代碼不立即執行,頁面會繼續載入,那defer中的代碼具體在什麼時候執行呢?在全部javascript代碼載入之後?頁面載入之後?onload之前還是之後?

答案是:

並不是說在網頁載入時不執行,可以在網頁寫一個SCRIPT.然後定義它,但是在載入時它還是執行了,
後來在找其它的東東時發現,因為它不有個子, 不知它是如何用,
原來它是在你的網頁已截入完成後,你想動態添加一個新的<script>時用的,如果你只是object.innerHTML = "<script" + ">"..."</script" + ">";
那麼當你調用你這個新定義的東東就會出錯,說還未定義,當你在上面的代碼加入defer時那麼你就能成功調用它,
在下面的代碼中你可以試下把它去掉, defer>";,那麼你就會發現問題!
<HTML>
<SCRIPT>
function insertScript(){
var sHTML="<input type=button onclick=" + "go2()" + " value='Click Me'><BR>";
var sScript="<SCRIPT defer>";
sScript = sScript + "function go2(){ alert('Hello from inserted script.') }";
sScript = sScript + "</SCRIPT" + ">";
ScriptDiv.innerHTML = sHTML + sScript;
}
</SCRIPT>
<BODY onload="insertScript();">
<DIV ID="ScriptDiv"></DIV>
</BODY>
</HTML>

//defer屬性指示該段腳本不會改變文檔的內容。在文檔完全顯示之前,js解釋器不執行這段代碼。
具體到這個例子,因為js不允許動態生成js代碼,所以去掉defer後產生的代碼會被認為是非法的。加上defer後的代碼,會被解釋器認為是載入頁面的時候跳過去的,可以執行。

<script src="../js/script.js" defer></script>
中的defer作用是文檔加載完畢了再執行腳本,這樣回避免找不到對象的問題

<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 等於在頁面完全在入後再執行,相當於 window.onload ,但應用上比 window.onload 更靈活!

defer是腳本程序強大功能中的一個“無名英雄”。它告訴浏覽器Script段包含了無需立即執行的代碼,並且,與SRC屬性聯合使用,它還可以使這些腳本在後台被下載,前台的內容則正常顯示給用戶。
--但是 文檔加載完畢了再執行腳本

最後請注意兩點:
1、不要在defer型的腳本程序段中調用document.write命令,因為document.write將產生直接輸出效果。
2、而且,不要在defer型腳本程序段中包括任何立即執行腳本要使用的全局變量或者函數。

一個常用的優化性能的方法是:當腳本不需要立即運行時,在<SCRIPT>標簽中設置“defer”屬性。 (立即腳本沒有被包含在一個function塊中,因此會在加載過程中執行。) 設置“defer”屬性後,IE就不必等待該腳本裝載和執行完畢。這樣頁面加載會更快。一般來說,這也表明立即腳本最好放在function塊中,並在document或者body對象的onload 句柄中處理該函數。在有一些腳本需要依賴用戶操作而執行時----例如點擊按鈕,或者移動鼠標到某個區域----使用該屬性非常有用。但當有一些腳本需要在頁面加載過程中或加載完成後執行,使用defer屬性得到的好處就不太大。
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved