溫馨提示×

溫馨提示×

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

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

html,css,js三者的加載順序是什么

發布時間:2021-08-02 14:36:48 來源:億速云 閱讀:472 作者:小新 欄目:web開發

這篇文章主要為大家展示了“html,css,js三者的加載順序是什么”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“html,css,js三者的加載順序是什么”這篇文章吧。

<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標簽

css文件的加載是與DOM的加載并行的,也就是說,css在加載時Dom還在繼續加載構建,而過程中遇到的css樣式或者img,則會向服務器發送一個請求,待資源返回后,將其添加到dom中的相對應位置中;

2、DOM加載到script標簽

由于js文件不會與DOM并行加載,因此需要等待js整個文件加載完之后才能繼續DOM的加載,倘若js腳本文件過大,則可能導致瀏覽器頁面顯示滯后,出現“假死”狀態,這種效應稱之為“阻塞效應”;會導致出現非常不好的用戶體驗;

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

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

3、解決方法

前提,js是外部腳本;

在script標簽中添加 defer=“ture”,則會讓js與DOM并行加載,待頁面加載完成后再執行js文件,這樣則不存在阻塞;

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

同時使用defer和async屬性時,defer屬性會失效;

可以將scirpt標簽放在body標簽之后,這樣就不會出現加載的沖突了。

以上是“html,css,js三者的加載順序是什么”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女