JS相關(guān)概念和瀏覽器渲染原理

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

CSS:css樣式放在head中,因?yàn)槿绻旁?lt;/body>標(biāo)簽的前面赊抖,那么當(dāng)DOM樹構(gòu)建完成了全谤,渲染樹才構(gòu)建,那么當(dāng)渲染樹構(gòu)建完成安皱,瀏覽器不得不再重新渲染整個(gè)頁面调鬓,這樣造成了資源的浪費(fèi)。如果放在<head> </head>之間酌伊,瀏覽器邊構(gòu)建邊渲染腾窝,效率高得多。
JS:js放在body 標(biāo)簽內(nèi)的最后居砖,script 標(biāo)簽內(nèi)虹脯。外鏈接用 <script src=""></script>,內(nèi)部的用 <script></script>奏候。這樣就不會(huì)出現(xiàn)網(wǎng)頁加載時(shí)白屏和FOUC的情況归形,可以確保在腳本執(zhí)行前頁面已經(jīng)完成了渲染。

2.解釋白屏和FOUC

白屏:

  • 如果把樣式放在底部鼻由,對(duì)于IE瀏覽器暇榴,在某些情景下,新窗口對(duì)于IE瀏覽器蕉世,在某些情景下(新窗口打開蔼紧,刷新等)頁面會(huì)出現(xiàn)白屏,而不是內(nèi)容逐漸展現(xiàn)
  • 如果使用@import標(biāo)簽狠轻,即使CSS放入link,并且放在頭部奸例,也可能出現(xiàn)白屏
  • 對(duì)于圖片和CSS, 在加載時(shí)會(huì)并發(fā)加載(如一個(gè)域名下同時(shí)加載兩個(gè)文件)。 但在加載 JavaScript 時(shí)向楼,會(huì)禁用并發(fā)查吊,并且阻止其他內(nèi)容的下載. 所以把 JavaScript 放入頁面頂部也會(huì)導(dǎo)致 白屏 現(xiàn)象.

FOUC(flash of unstyled content)無樣式內(nèi)容閃爍:

  • 如果把樣式放在底部,對(duì)于IE瀏覽器湖蜕,在某些場(chǎng)景下(點(diǎn)擊鏈接逻卖,輸入U(xiǎn)RL,使用書簽進(jìn)入等)昭抒,會(huì)出現(xiàn)FOUC現(xiàn)象(逐步加載無樣式的內(nèi)容评也,等CSS記載后頁面突然展現(xiàn)樣式)炼杖。對(duì)于Firefox會(huì)一直表現(xiàn)出FOUC

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

  • 沒有defer或async盗迟,瀏覽器會(huì)立即加載并指定的腳本坤邪,“立即”指的是在渲染該 script 標(biāo)簽之下的文檔元素之前,也就是說不等待后續(xù)載入的文檔元素罚缕,讀到就加載并執(zhí)行艇纺。
  • 有 async,加載和渲染后續(xù)文檔元素的過程將和 script.js 的加載與執(zhí)行并行進(jìn)行(異步)邮弹。
  • 有 defer喂饥,加載后續(xù)文檔元素的過程將和 script.js 的加載并行進(jìn)行(異步),但 script.js 的執(zhí)行要在所有元素解析完成之后肠鲫,DOMContentLoaded 事件觸發(fā)之前完成。
  • 瀏覽器在解析HTML文件時(shí)或粮,遇上沒有設(shè)置defer或async屬性的腳本导饲,瀏覽器讀到該腳本就加載并執(zhí)行,腳本會(huì)阻塞其后內(nèi)容的執(zhí)行氯材;
  • 遇上設(shè)有async屬性的腳本渣锦,會(huì)在HTML解析過程中下載該腳本,并在完成下載后暫停HTML的解析來執(zhí)行這個(gè)異步腳本氢哮,直到執(zhí)行完成后再繼續(xù)HTML的解析袋毙;
  • 遇上有defer屬性的腳本,會(huì)在HTML解析過程中下載該腳本冗尤,在HTML解析完成后才執(zhí)行該文件听盖,延遲腳本按照它們?cè)谖臋n中出現(xiàn)的順序執(zhí)行。
  • async屬性可以保證腳本下載的同時(shí)裂七,瀏覽器進(jìn)行渲染皆看。需要注意的是,一旦采用這個(gè)屬性就無法保證腳本的執(zhí)行順序背零。哪個(gè)腳本先下載結(jié)束腰吟,就先執(zhí)行哪個(gè)腳本。

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

  1. 解析html標(biāo)簽徙瓶,構(gòu)建dom樹
  2. 解析css標(biāo)簽毛雇,構(gòu)建cssom樹
  3. 把dom和cssom組合成渲染樹(render tree)
  4. 在渲染樹的基礎(chǔ)上進(jìn)行布局,計(jì)算每個(gè)節(jié)點(diǎn)的幾何結(jié)構(gòu)
  5. 把每個(gè)節(jié)點(diǎn)繪制到屏幕上(painting)
    chrome等瀏覽器


    1739898-56a58b58bb5dcc0e.png

Mozilla 的 Gecko 呈現(xiàn)引擎主流程(firefox瀏覽器)

image008.jpg

  • 解析 HTML 標(biāo)簽到 Content Sink

  • 這時(shí)侦镇,先加載Content Sink 里面的內(nèi)容灵疮,頁面上會(huì)顯示一個(gè)無樣式的內(nèi)容

  • 循環(huán)加載 CSS 樣式,每次加載一部分 CSS 樣式后壳繁,會(huì)重新渲染頁面

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末始藕,一起剝皮案震驚了整個(gè)濱河市蒲稳,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌伍派,老刑警劉巖江耀,帶你破解...
    沈念sama閱讀 217,185評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異诉植,居然都是意外死亡祥国,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門晾腔,熙熙樓的掌柜王于貴愁眉苦臉地迎上來舌稀,“玉大人,你說我怎么就攤上這事灼擂”诓椋” “怎么了?”我有些...
    開封第一講書人閱讀 163,524評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵剔应,是天一觀的道長(zhǎng)睡腿。 經(jīng)常有香客問我,道長(zhǎng)峻贮,這世上最難降的妖魔是什么席怪? 我笑而不...
    開封第一講書人閱讀 58,339評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮纤控,結(jié)果婚禮上挂捻,老公的妹妹穿的比我還像新娘。我一直安慰自己船万,他們只是感情好刻撒,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,387評(píng)論 6 391
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著耿导,像睡著了一般疫赎。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上碎节,一...
    開封第一講書人閱讀 51,287評(píng)論 1 301
  • 那天捧搞,我揣著相機(jī)與錄音,去河邊找鬼狮荔。 笑死胎撇,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的殖氏。 我是一名探鬼主播晚树,決...
    沈念sama閱讀 40,130評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼雅采!你這毒婦竟也來了爵憎?” 一聲冷哼從身側(cè)響起慨亲,我...
    開封第一講書人閱讀 38,985評(píng)論 0 275
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎宝鼓,沒想到半個(gè)月后刑棵,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,420評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡愚铡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,617評(píng)論 3 334
  • 正文 我和宋清朗相戀三年蛉签,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片沥寥。...
    茶點(diǎn)故事閱讀 39,779評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡碍舍,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出邑雅,到底是詐尸還是另有隱情片橡,我是刑警寧澤,帶...
    沈念sama閱讀 35,477評(píng)論 5 345
  • 正文 年R本政府宣布淮野,位于F島的核電站捧书,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏录煤。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,088評(píng)論 3 328
  • 文/蒙蒙 一荞胡、第九天 我趴在偏房一處隱蔽的房頂上張望妈踊。 院中可真熱鬧,春花似錦泪漂、人聲如沸廊营。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽露筒。三九已至,卻和暖如春敌卓,著一層夾襖步出監(jiān)牢的瞬間慎式,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工趟径, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留瘪吏,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,876評(píng)論 2 370
  • 正文 我出身青樓蜗巧,卻偏偏與公主長(zhǎng)得像掌眠,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子幕屹,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,700評(píng)論 2 354

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

  • 簡(jiǎn)單介紹JavaScript的發(fā)展歷史 JavaScript因互聯(lián)網(wǎng)而生蓝丙,回顧它的歷史要從瀏覽器的歷史講起级遭。 19...
    _Dot912閱讀 490評(píng)論 0 3
  • 標(biāo)識(shí)符 所謂標(biāo)識(shí)符是指變量、函數(shù)渺尘、屬性的名字挫鸽,或者函數(shù)的參數(shù)。標(biāo)識(shí)符的書寫有幾個(gè)特征: 區(qū)分大小寫 第一個(gè)字符必須...
    yuhuan121閱讀 817評(píng)論 0 1
  • 1. CSS和JS在網(wǎng)頁中的放置順序是怎樣的沧烈? css放在head標(biāo)簽內(nèi)掠兄,防止渲染時(shí)出現(xiàn)白屏 js放在最后body...
    billa_8f6b閱讀 574評(píng)論 0 0
  • 1、CSS和JS在網(wǎng)頁中的放置順序是怎樣的锌雀? (1)CSS 對(duì)于谷歌瀏覽器和Safari放在head里或body里...
    徐國(guó)軍_plus閱讀 445評(píng)論 0 0
  • ======================第一部分===================== =========...
    65_劉璐閱讀 557評(píng)論 0 1