JS與頁面渲染機(jī)制相關(guān)概念

CSS和JS在網(wǎng)頁中的放置順序是怎樣的聪黎?

  • JS一般放置在</body>標(biāo)簽之前或添加defer屬性

    1. JS是阻塞加載莉掂,會阻塞DOM樹或阻塞渲染樹的構(gòu)建。
    2. JS 可能會修改 DOM,如果在DOM樹加載完成前修改DOM會導(dǎo)致JS代碼無效溪胶。
    3. JS可能會通過操作DOM對象的class來改變DOM,因此必須保證CSS在JS之前加載和解析完成稳诚。
  • CSS一般放置在head標(biāo)簽內(nèi)

    由于Render Tree是由DOM樹和CSSOM樹組合成的哗脖,html頁面需要等到CSS解析完后才能完成渲染,所以CSS應(yīng)放在head標(biāo)簽內(nèi)采桃,優(yōu)先下載解析懒熙,以避免頁面元素由于樣式缺失造成瞬間的白頁或者給用戶閃爍感。

白屏和FOUC

  • 當(dāng)把CSS樣式放在底部或者使用@import方式引入樣式普办、或?qū)S放在頭部造成其他內(nèi)容阻塞加載時:
    • 一些瀏覽器例如chrome,他的加載和渲染機(jī)制是等頭部的JS和底部的CSS全部加載解析完后再渲染展示頁面,而這個等待的時間就為白屏工扎。
    • 另一些瀏覽器例如Firefox,他會在CSS未加載前先展現(xiàn)頁面,等css加載后再重繪一次,這就造成了FOUC (無樣式內(nèi)容閃爍)。

async和defer的作用是什么衔蹲?有什么區(qū)別

  • 當(dāng)瀏覽器碰到<script>標(biāo)簽時:
    • 瀏覽器會立即加載并執(zhí)行指定的腳本肢娘,并且阻塞后續(xù)的頁面渲染。
    • 有 async時舆驶,加載和渲染后續(xù)文檔元素的過程將和 js腳本 的加載與執(zhí)行并行進(jìn)行(異步)橱健。有 async 的情況下,JavaScript 腳本一旦下載好了就會執(zhí)行沙廉,所以很有可能不是按照原本的順序來執(zhí)行的拘荡。如果 JavaScript 腳本前后有依賴性,使用 async 就很有可能出現(xiàn)錯誤撬陵。
    • 有 defer時珊皿,加載后續(xù)文檔元素的過程將和 js腳本 的加載并行進(jìn)行(異步)网缝,但是 js腳本 的執(zhí)行要在DOM加載完成之后,DOMContentLoaded 事件觸發(fā)之前完成蟋定。

簡述網(wǎng)頁的渲染機(jī)制

  1. 解析html構(gòu)建DOM樹
  2. 解析CSS構(gòu)建CSSOM樹
  3. 把DOM和CSSOM組合成渲染樹(Render Tree)
  4. 在渲染樹的基礎(chǔ)上進(jìn)行布局粉臊,計算每個節(jié)點(diǎn)的幾何結(jié)構(gòu)(Layout Tree)
  5. 把每個節(jié)點(diǎn)繪制到屏幕上(Painting)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市驶兜,隨后出現(xiàn)的幾起案子扼仲,更是在濱河造成了極大的恐慌,老刑警劉巖抄淑,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件屠凶,死亡現(xiàn)場離奇詭異,居然都是意外死亡蝇狼,警方通過查閱死者的電腦和手機(jī)阅畴,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進(jìn)店門倡怎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來迅耘,“玉大人,你說我怎么就攤上這事监署〔ǎ” “怎么了?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵钠乏,是天一觀的道長栖秕。 經(jīng)常有香客問我,道長晓避,這世上最難降的妖魔是什么簇捍? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮俏拱,結(jié)果婚禮上暑塑,老公的妹妹穿的比我還像新娘。我一直安慰自己锅必,他們只是感情好事格,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著搞隐,像睡著了一般驹愚。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上劣纲,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天逢捺,我揣著相機(jī)與錄音,去河邊找鬼癞季。 笑死劫瞳,一個胖子當(dāng)著我的面吹牛棠耕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播柠新,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼窍荧,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了恨憎?” 一聲冷哼從身側(cè)響起蕊退,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎憔恳,沒想到半個月后瓤荔,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡钥组,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年输硝,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片程梦。...
    茶點(diǎn)故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡点把,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出屿附,到底是詐尸還是另有隱情郎逃,我是刑警寧澤,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布挺份,位于F島的核電站褒翰,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏匀泊。R本人自食惡果不足惜优训,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望各聘。 院中可真熱鬧揣非,春花似錦、人聲如沸伦吠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽毛仪。三九已至搁嗓,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間箱靴,已是汗流浹背腺逛。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留衡怀,地道東北人棍矛。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓安疗,卻偏偏與公主長得像,于是被迫代替她去往敵國和親够委。 傳聞我的和親對象是個殘疾皇子荐类,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,037評論 2 355

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

  • 1. CSS和JS在網(wǎng)頁中的放置順序是怎樣的? css放在head標(biāo)簽內(nèi)茁帽,防止渲染時出現(xiàn)白屏 js放在最后body...
    billa_8f6b閱讀 574評論 0 0
  • 簡單介紹JavaScript的發(fā)展歷史 JavaScript因互聯(lián)網(wǎng)而生玉罐,回顧它的歷史要從瀏覽器的歷史講起。 19...
    _Dot912閱讀 490評論 0 3
  • 作為一個前端開發(fā)潘拨,有必要了解從我們在瀏覽器地址欄輸入網(wǎng)址到看到頁面這期間瀏覽器是如何進(jìn)行工作的,進(jìn)而了解如何更好的...
    李奕錦liyijin閱讀 546評論 0 0
  • 大家都知道萬維網(wǎng)的應(yīng)用層使用了HTTP協(xié)議吊输,并且用瀏覽器作為入口訪問網(wǎng)絡(luò)上的資源。用戶在使用瀏覽器訪問一個網(wǎng)站時需...
    SylvanasSun閱讀 2,149評論 1 12
  • 我們都想做一個成功的人,既有錢琅束,又成功扭屁。 那么,成功的人怎么定義呢狰闪?怎樣才能被定位為成功的人疯搅? 1濒生、有能力實(shí)現(xiàn)自己...
    夢想搬磚者閱讀 497評論 0 2