亚洲3P视频,日韩BBW无码,亚洲制服麻豆网站,88re伊人,九草精品视频在线观看,国产精品久久夜,色青青狠狠色,无码熟女一区二区三区,日本一区二区成人网站

新聞建站cms系統(tǒng)、政府cms系統(tǒng)定制開發(fā)

廣州網(wǎng)站建設(shè)公司-閱速公司

asp.net新聞發(fā)布系統(tǒng)、報(bào)紙數(shù)字報(bào)系統(tǒng)方案
/
http://m.duxiu2008.cn/
廣州網(wǎng)站建設(shè)公司
您當(dāng)前位置:首頁>網(wǎng)站技術(shù)

網(wǎng)站技術(shù)

異步加載javascript腳本的幾種方式(async)

發(fā)布時(shí)間:2017/7/3 12:30:29  作者:Admin  閱讀:486  

廣告:

如果在head或者body的前面放入過多的script標(biāo)簽,并且內(nèi)容很多的時(shí)候,會(huì)造成頁面在解析完所有script標(biāo)簽的內(nèi)容前有短暫的時(shí)間整個(gè)頁面空白,給用戶的體驗(yàn)會(huì)很差。但是如果所有的腳本都放在底部,又會(huì)造成dom加載完畢后有一段時(shí)間頁面雖然能看到,但是和用戶的交互卻很差,因此需要讓一些腳本與頁面異步加載。

1.在html5中,script新增了async的屬性,script添加了該屬性之后,下載腳本時(shí)將可以與頁面其他內(nèi)容并行下載,但是該屬性必須在ie9以上的瀏覽器中才可以使用,并且只能用于加載外部js腳本。

<script async src="siteScript.js" onload="myInit()"></script>

onload 在microsft edge和ihphone手機(jī)瀏覽器不支持,myinit事件最好寫在 siteScripts.js里面。不然會(huì)導(dǎo)致不同步出錯(cuò)。

正確:<script async src="siteScript.js" ></script>

2.同樣,在html4中也有一個(gè)defer屬性,該屬性的兼容性更好一點(diǎn),但是與async一樣,可以讓js腳本實(shí)現(xiàn)異步加載,同樣只能用于加載外部js腳本。

顯示的順序?yàn)椋簄ormal defer window.onload

3.利用XHR異步加載js內(nèi)容并執(zhí)行,代碼如下

<script>

var xhr = new XMLHttpRequest();

xhr.open("get", "js/defer.js",true)

xhr.send();

xhr.onreadystatechange = function() {

if (xhr.readyState == 4 && xhr.status == 200) {

eval(xhr.responseText);

}

}

</script>

4.動(dòng)態(tài)創(chuàng)建script標(biāo)簽,主要代碼如下

var script = document.createElement("script");

script.src = "js/test.js";

document.head.appendChild(script);

5.iframe方式,利用iframe加載一個(gè)同源的子頁面,讓子頁面內(nèi)的js影響當(dāng)前父頁面的一種方式。

html5代碼標(biāo)準(zhǔn)檢驗(yàn)

http://validator.w3.org/

http://html5test.com/

說明:

1. js文件放在html頁面底部,則不影響頁面顯示和圖片下載,但是js事件要等到底部js下載完才會(huì)加載。

2. js文件放在head之間,則影響頁面顯示和圖片顯示,打開空白,要等js下載完才會(huì)加載文字和圖片。

廣告:

相關(guān)文章
異步
async
cms新聞系統(tǒng)購(gòu)買咨詢
掃描關(guān)注 廣州閱速軟件科技有限公司
掃描關(guān)注 廣州閱速科技
朝阳区| 石渠县| 河曲县| 望江县| 南陵县| 勐海县| 乌苏市| 永昌县| 清新县| 中方县| 阳江市| 高尔夫| 保定市| 沅陵县| 凭祥市| 始兴县| 大悟县| 长沙县| 陕西省| 望都县| 靖边县| 荆州市| 泗水县| 突泉县| 涟水县| 台江县| 泸定县| 普陀区| 苏尼特左旗| 通州区| 泸溪县| 乐东| 古交市| 千阳县| SHOW| 浑源县| 许昌县| 竹溪县| 托里县| 沿河| 眉山市|