vip10-1225作業(yè)

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


  • CSS應(yīng)該放在頁面頂部的head標(biāo)簽中
    由于Render Tree是由DOM樹和CSSOM樹組合成的,html頁面需要等到CSS解析完后才能完成渲染绑改,所以CSS應(yīng)放在head標(biāo)簽內(nèi),優(yōu)先下載解析,以避免頁面元素由于樣式缺失造成瞬間的白屏和閃爍。

  • JS應(yīng)該放在body的底部

  1. 因為瀏覽器需要一個穩(wěn)定的dom樹結(jié)構(gòu),而且js中很有可能有代碼直接改變了dom樹結(jié)構(gòu)合愈,瀏覽器為了防止出現(xiàn)js修改dom樹,需要重新構(gòu)建dom樹的情況击狮,所以就會阻塞其他的下載和呈現(xiàn)。
  2. 將JavaScript放在head內(nèi)和body底部的區(qū)別也在于此益老,放在head里面彪蓬,由于瀏覽器發(fā)現(xiàn)head里面有JavaScript標(biāo)簽就會暫時停止其他渲染行為,等待JavaScript下載并執(zhí)行完成才能接著往下渲染捺萌,而這個時候由于在head里面這個時候頁面是白的档冬;如果JavaScript放在頁面底部,render Tree已經(jīng)完成大部分桃纯,所以此時頁面有內(nèi)容呈現(xiàn)酷誓,即使遇到JavaScript阻塞渲染,也不會有白屏出現(xiàn)态坦。
  • 如果CSS和JS都在head標(biāo)簽內(nèi)盐数,則應(yīng)將JS放在所有CSS的前面
    head里的內(nèi)聯(lián)js只要在所有外聯(lián)css前面,css文件就可以和body里的請求并行伞梯。因為JS 的執(zhí)行有可能依賴最新樣式玫氢。比如,可能會有 var width = $('#id').width(). 這意味著谜诫,JS 代碼在執(zhí)行前漾峡,瀏覽器必須保證在此 JS 之前的所有 css(無論外鏈還是內(nèi)嵌)都已下載和解析完成。這是 CSS 阻塞后續(xù) JS 執(zhí)行的根本原因喻旷。

問題2:解釋白屏和FOUC


  • 白屏和fouc并不是bug生逸,而是不同瀏覽器加載和顯示機(jī)制不同造成的。解決方法就是使用link標(biāo)簽將樣式表放置在head標(biāo)簽中
  • 白屏
    1.當(dāng)把css樣式放在底部或者使用@import方式引入樣式時一些瀏覽器例如chrome和IE,他的加載和渲染機(jī)制是等css全部加載解析完后再渲染展示頁面槽袄,而這個等待的時間就為白屏烙无。
    2.如果把js文件放在頭部,腳本會阻塞后面內(nèi)容的呈現(xiàn)掰伸,腳本會阻塞其后組件的下載皱炉,出現(xiàn)白屏問題。
  • FOUC
    逐步加載無樣式的內(nèi)容,等CSS加載后頁面突然展現(xiàn)樣式
    1.如果把CSS樣式放在底部,對于IE瀏覽器,在某些場景下(點擊鏈接,輸入URL,使用書簽進(jìn)入等),會出現(xiàn) FOUC .
    2.另一些瀏覽器例如Firefox,他會在css未加載前先展現(xiàn)頁面,等css加載后再重新對樣式進(jìn)行修改,這就造成了FOUC 狮鸭。

問題3:async和defer的作用是什么合搅?有什么區(qū)別?


  • 如果既不使用 async 也不使用 defer:在瀏覽器繼續(xù)解析頁面之前歧蕉,立即讀取并執(zhí)行腳本灾部。
    默認(rèn)引用 script:<script type="text/javascript" src="script.js"></script>
    當(dāng)瀏覽器遇到 script 標(biāo)簽時,文檔的解析將停止惯退,并立即下載并執(zhí)行腳本赌髓,腳本執(zhí)行完畢后將繼續(xù)解析文檔。

  • async模式 <script type="text/javascript" src="script.js" async="async"></script>
    當(dāng)瀏覽器遇到 script 標(biāo)簽時催跪,文檔的解析不會停止锁蠕,其他線程將下載腳本,腳本下載完成后開始執(zhí)行腳本懊蒸,腳本執(zhí)行的過程中文檔將停止解析荣倾,直到腳本執(zhí)行完畢。

  • defer模式 <script type="text/javascript" src="script.js" defer="defer"></script>
    當(dāng)瀏覽器遇到 script 標(biāo)簽時骑丸,文檔的解析不會停止舌仍,其他線程將下載腳本,待到文檔解析完成通危,腳本才會執(zhí)行铸豁。

  • 區(qū)別
    最主要的區(qū)別就是async是異步下載并立即執(zhí)行,然后文檔繼續(xù)解析菊碟,defer是異步加載后解析文檔节芥,然后再執(zhí)行腳本。

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


  1. 瀏覽器解析(包括HTML,SVG,XHTML,CSS,JavaScript等等)
    解析HTML代碼框沟,構(gòu)建Document Object Model (DOM)
    解析CSS代碼藏古,構(gòu)建CSS Object Model (CSSOM)
    JavaSript通過API操作DOM和CSSOM,
    渲染樹構(gòu)建過程如下:


  2. 布局階段
    在屏幕上繪制渲染樹中的所有節(jié)點的幾何屬性,比如: 位置忍燥,寬高拧晕,大小等等

  3. 繪制元素
    繪制所有節(jié)點的可視屬性,比如:顏色梅垄,背景厂捞,邊框输玷,背景圖等,這期間可能會產(chǎn)生多個圖層(堆疊上下文)靡馁。

  4. 合并渲染層
    把以上繪制的所有圖層(類似于PhotoShop中的“圖層”)合并,最終輸出一張圖片欲鹏。

文/饑人谷小霾(簡書作者)著作權(quán)歸作者所有,轉(zhuǎn)載請聯(lián)系作者獲得授權(quán)臭墨,并標(biāo)注“簡書作者”赔嚎。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市胧弛,隨后出現(xiàn)的幾起案子尤误,更是在濱河造成了極大的恐慌,老刑警劉巖结缚,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件损晤,死亡現(xiàn)場離奇詭異,居然都是意外死亡红竭,警方通過查閱死者的電腦和手機(jī)尤勋,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來茵宪,“玉大人最冰,你說我怎么就攤上這事∠』穑” “怎么了锌奴?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長憾股。 經(jīng)常有香客問我,道長箕慧,這世上最難降的妖魔是什么服球? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮颠焦,結(jié)果婚禮上斩熊,老公的妹妹穿的比我還像新娘。我一直安慰自己伐庭,他們只是感情好粉渠,可當(dāng)我...
    茶點故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著圾另,像睡著了一般霸株。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上集乔,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天去件,我揣著相機(jī)與錄音,去河邊找鬼。 笑死尤溜,一個胖子當(dāng)著我的面吹牛倔叼,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播宫莱,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼丈攒,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了授霸?” 一聲冷哼從身側(cè)響起巡验,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎绝葡,沒想到半個月后深碱,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡藏畅,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年敷硅,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片愉阎。...
    茶點故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡绞蹦,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出榜旦,到底是詐尸還是另有隱情幽七,我是刑警寧澤,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布溅呢,位于F島的核電站澡屡,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏咐旧。R本人自食惡果不足惜驶鹉,卻給世界環(huán)境...
    茶點故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望铣墨。 院中可真熱鬧室埋,春花似錦、人聲如沸伊约。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽屡律。三九已至腌逢,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間超埋,已是汗流浹背上忍。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工骤肛, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人窍蓝。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓腋颠,卻偏偏與公主長得像,于是被迫代替她去往敵國和親吓笙。 傳聞我的和親對象是個殘疾皇子淑玫,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,614評論 2 353

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

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標(biāo)簽?zāi)J(rèn)的外補(bǔ)...
    _Yfling閱讀 13,748評論 1 92
  • 轉(zhuǎn)載說明 一面睛、介紹 瀏覽器可以被認(rèn)為是使用最廣泛的軟件絮蒿,本文將介紹瀏覽器的工作原理,我們將看到叁鉴,從你在地址欄輸入g...
    17碎那年閱讀 2,447評論 0 22
  • 簡介瀏覽器可以被認(rèn)為是使用最廣泛的軟件幌墓,本文將介紹瀏覽器的工 作原理但壮,我們將看到,從你在地址欄輸入google.c...
    聽風(fēng)閣閱讀 3,285評論 0 7
  • 目錄一常侣、介紹二蜡饵、渲染引擎三、解析與DOM樹構(gòu)建四胳施、渲染樹構(gòu)建五溯祸、布局六、繪制七舞肆、動態(tài)變化八焦辅、渲染引擎的線程九、CS...
    饑人谷_米彌輪閱讀 2,457評論 0 10
  • 一:在制作一個Web應(yīng)用或Web站點的過程中椿胯,你是如何考慮他的UI氨鹏、安全性、高性能压状、SEO、可維護(hù)性以及技術(shù)因素的...
    Arno_z閱讀 1,156評論 0 1