DOMContentLoaded與load的區(qū)別、觸發(fā)時機

一、DOMContentLoaded 與 load 事件

關(guān)于 DOMContentLoaded 和 load 事件,MDN對他們是這樣描述的:DOMContentLoaded 文檔地址撞蜂、load 文檔地址

DOMContentLoaded 意思就是:當(dāng)初始的 HTML 文檔被完全加載和解析完成之后侥袜,DOMContentLoaded 事件被觸發(fā)蝌诡,而無需等待樣式表、圖像和子框架的完成加載枫吧。

load 意思就是:當(dāng)一個資源及其依賴資源已完成加載時浦旱,將觸發(fā) load 事件。

區(qū)別小結(jié)
簡而言之九杂,二者觸發(fā)時間的區(qū)別在于:DOMContentLoaded 在 HTML 文檔本解析之后觸發(fā)颁湖,而 load 是在 HTML 所有相關(guān)資源被加載完成后觸發(fā)。
為了感受這兩個事件例隆,可以使用 Chrome 打開一個任意網(wǎng)頁甥捺。打開控制臺的 Network 面板。

可以看到圖上有兩條線:一條藍線镀层,代表 DOMContentLoaded 事件镰禾,觸發(fā)時間為 1.50s;一條紅線,代表 load 事件吴侦,觸發(fā)時間為 5.54s屋休。
如果想要更直觀地感受二者的區(qū)別,還可以 點擊這里 查看效果备韧。

二劫樟、HTML 解析過程與 DOMContentLoaded 觸發(fā)時機

我們已經(jīng)知道 DOMContentLoaded 的觸發(fā)時間為:當(dāng) HTML 文檔被加載和解析完成。那么我們還需要理解 HTML 的解析過程织堂。

  1. 在既沒有 CSS 也沒有 JS 的情況下叠艳,HTML 文檔的解析過程為:

    DOMContentLoaded 事件的觸發(fā)時機為:HTML 解析為 DOM 之后。

  2. 有 CSS 無 JS 的情況下易阳,HTML 文檔解析過程為:

    這里與 1. 不同的地方在于附较,渲染樹的生成是基于 DOM 和 CSSOM 的。但是觸發(fā) DOMContentLoaded 的時間依然是在 HTML 解析為 DOM 后闽烙,無論此時 CSS 解析為 CSSOM 的過程是否完成。

  3. 當(dāng)有 JS 時声搁,HTML 文檔解析過程為:

    有一個問題:關(guān)于首屏?xí)r間黑竞?
    “計算這個網(wǎng)頁從空白到出現(xiàn)內(nèi)容所發(fā)費的時間”。那怎么計算這段時間疏旨?這段時間其實就是 HTML 文檔加載和解析的時間很魂。也就是 DOMContentLoaded 事件觸發(fā)之前所經(jīng)歷的時間。
    所以檐涝,對于首屏?xí)r間而言遏匆,js 放在 HTML 文檔的開頭和結(jié)尾處效果是一樣的而 js 放在結(jié)尾的目的并不是為了減少首屏?xí)r間,而是由于 js 經(jīng)常需要操縱 DOM谁榜,放在后面才更能保證找到 DOM 節(jié)點幅聘。

待進一步探究

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市窃植,隨后出現(xiàn)的幾起案子帝蒿,更是在濱河造成了極大的恐慌,老刑警劉巖巷怜,帶你破解...
    沈念sama閱讀 219,039評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件葛超,死亡現(xiàn)場離奇詭異,居然都是意外死亡延塑,警方通過查閱死者的電腦和手機绣张,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來关带,“玉大人侥涵,你說我怎么就攤上這事。” “怎么了独令?”我有些...
    開封第一講書人閱讀 165,417評論 0 356
  • 文/不壞的土叔 我叫張陵端朵,是天一觀的道長。 經(jīng)常有香客問我燃箭,道長冲呢,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,868評論 1 295
  • 正文 為了忘掉前任招狸,我火速辦了婚禮敬拓,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘裙戏。我一直安慰自己乘凸,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,892評論 6 392
  • 文/花漫 我一把揭開白布累榜。 她就那樣靜靜地躺著营勤,像睡著了一般。 火紅的嫁衣襯著肌膚如雪壹罚。 梳的紋絲不亂的頭發(fā)上葛作,一...
    開封第一講書人閱讀 51,692評論 1 305
  • 那天,我揣著相機與錄音猖凛,去河邊找鬼赂蠢。 笑死,一個胖子當(dāng)著我的面吹牛辨泳,可吹牛的內(nèi)容都是我干的虱岂。 我是一名探鬼主播,決...
    沈念sama閱讀 40,416評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼菠红,長吁一口氣:“原來是場噩夢啊……” “哼第岖!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起试溯,我...
    開封第一講書人閱讀 39,326評論 0 276
  • 序言:老撾萬榮一對情侶失蹤绍傲,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后耍共,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體烫饼,經(jīng)...
    沈念sama閱讀 45,782評論 1 316
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,957評論 3 337
  • 正文 我和宋清朗相戀三年试读,在試婚紗的時候發(fā)現(xiàn)自己被綠了杠纵。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,102評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡钩骇,死狀恐怖比藻,靈堂內(nèi)的尸體忽然破棺而出铝量,到底是詐尸還是另有隱情,我是刑警寧澤银亲,帶...
    沈念sama閱讀 35,790評論 5 346
  • 正文 年R本政府宣布慢叨,位于F島的核電站,受9級特大地震影響务蝠,放射性物質(zhì)發(fā)生泄漏拍谐。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,442評論 3 331
  • 文/蒙蒙 一馏段、第九天 我趴在偏房一處隱蔽的房頂上張望轩拨。 院中可真熱鬧,春花似錦院喜、人聲如沸亡蓉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽砍濒。三九已至,卻和暖如春硫麻,著一層夾襖步出監(jiān)牢的瞬間爸邢,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評論 1 272
  • 我被黑心中介騙來泰國打工庶香, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留甲棍,地道東北人简识。 一個月前我還...
    沈念sama閱讀 48,332評論 3 373
  • 正文 我出身青樓赶掖,卻偏偏與公主長得像,于是被迫代替她去往敵國和親七扰。 傳聞我的和親對象是個殘疾皇子奢赂,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,044評論 2 355

推薦閱讀更多精彩內(nèi)容