国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

詳解關(guān)于html,css,js三者的加載順序問題

2019-11-19 11:49:16
字體:
供稿:網(wǎng)友
<head lang="en">  <meta charset="utf-8">  <title></title>  <link rel="stylesheet" href="css/*.css" rel="external nofollow" >  <script src="js/*.js></script></head>

DOM文檔的加載順序是由上而下的順序加載;

1、DOM加載到link標(biāo)簽

css文件的加載是與DOM的加載并行的,也就是說,css在加載時(shí)Dom還在繼續(xù)加載構(gòu)建,而過程中遇到的css樣式或者img,則會(huì)向服務(wù)器發(fā)送一個(gè)請(qǐng)求,待資源返回后,將其添加到dom中的相對(duì)應(yīng)位置中;

2、DOM加載到script標(biāo)簽

由于js文件不會(huì)與DOM并行加載,因此需要等待js整個(gè)文件加載完之后才能繼續(xù)DOM的加載,倘若js腳本文件過大,則可能導(dǎo)致瀏覽器頁(yè)面顯示滯后,出現(xiàn)“假死”狀態(tài),這種效應(yīng)稱之為“阻塞效應(yīng)”;會(huì)導(dǎo)致出現(xiàn)非常不好的用戶體驗(yàn);

而這個(gè)特性也是為什么在js文件中開頭需要$(document).ready(function(){})或者(function(){})或者window.onload,即是讓DOM文檔加載完成之后才執(zhí)行js文件,這樣才不會(huì)出現(xiàn)查找不到DOM節(jié)點(diǎn)等問題;

js阻塞其他資源的加載的原因是:瀏覽器為了防止js修改DOM樹,需要重新構(gòu)建DOM樹的情況出現(xiàn);

3、解決方法

前提,js是外部腳本;

在script標(biāo)簽中添加 defer=“ture”,則會(huì)讓js與DOM并行加載,待頁(yè)面加載完成后再執(zhí)行js文件,這樣則不存在阻塞;

在scirpt標(biāo)簽中添加 async=“ture”,這個(gè)屬性告訴瀏覽器該js文件是異步加載執(zhí)行的,也就是不依賴于其他js和css,也就是說無法保證js文件的加載順序,但是同樣有與DOM并行加載的效果;

同時(shí)使用defer和async屬性時(shí),defer屬性會(huì)失效;

可以將scirpt標(biāo)簽放在body標(biāo)簽之后,這樣就不會(huì)出現(xiàn)加載的沖突了。

以上所述是小編給大家介紹的關(guān)于html,css,js三者的加載順序問題詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)武林網(wǎng)網(wǎng)站的支持!

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 宜君县| 日照市| 加查县| 隆昌县| 黔江区| 定陶县| 尉氏县| 江安县| 建阳市| 横山县| 潞城市| 微山县| 罗山县| 全南县| 卫辉市| 准格尔旗| 永嘉县| 徐汇区| 宁城县| 平山县| 惠来县| 东乌珠穆沁旗| 清河县| 平陆县| 乐昌市| 高清| 辽宁省| 驻马店市| 屏南县| 汝阳县| 扎囊县| 邵阳县| 尉氏县| 济源市| 抚顺县| 永修县| 湄潭县| 新闻| 理塘县| 惠州市| 汤原县|