中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

html中的body沒有高度設置背景色為什么可以全屏顯示

發布時間:2022-03-08 14:21:48 來源:億速云 閱讀:451 作者:小新 欄目:web開發

小編給大家分享一下html中的body沒有高度設置背景色為什么可以全屏顯示,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

  --- 關于html和body的那些事

  還記得我們開發全屏頁面或者是移動端頁面時經常會設置一句話

  html, body { height: 100%; }

  是不是只知道用?卻不知道怎么回事?

  原因是,當沒有內容撐開高度時,html和body的默認高度是0,如果內容想要按照比例或是撐滿全屏時,就沒辦法正常使用百分比

  而如果只設置body { height: 100%; },這時body以html的高度為基準,但html默認高度也是0,所以需要設置html與body高度同與瀏覽器等高

  但!

  當我們沒有設置任何高度的情況下,給body設置背景色,顏色竟然是可以布滿瀏覽器的,然而可以看到控制臺中,body實實在在是沒有高度的,這究竟是為什么呢?

  body {

  background: pink;

  }

  事實上,當我們單獨給body設置背景顏色時,并不是body標簽被賦予了背景色,而是【 瀏覽器畫布 】賦上了顏色,可以理解為,body的背景色被瀏瀏覽器”吃掉“

  那如果我們同時給html與body設置背景色,會發生什么樣的結果呢

  html {

  background: orange;

  }

  body {

  background: pink;

  }

  可以看到,我們設置的body背景色竟然“失效了”,瀏覽器被賦予了html的背景色

  而在我看來,實際是我們設置的body背景色[生效了],但因body默認高度為0,所以在頁面中并沒有粉色區塊顯示,那我們嘗試在body中添加一些內容

  可以看出,body的高度被撐開,而body的背景色則是實實在在只給了body

  所以我們可以得出一個結論

  瀏覽器會“吸收”html與body的背景色

  當只設置了body背景色時,瀏覽器發現了,于是把這個背景色“占為己有”

  而如果html設置了背景色,瀏覽器則會認為html離我更近,所以會“拿走”html的背景色當成自己的顏色

  當然,到現在為止,我們實驗的都是純色背景,那如果我們設置成漸變色,還是相同的結果嗎?

  疑問產生,開始實驗

  首先,只設置body的背景為線性漸變粉色pink到白色#fff,預想結果應該是和背景一樣,直接瀏覽器從上往下的漸變

  body {

  background: linear-gradient(pink, #fff);

  }

  嗯?這怎么和預想不一樣,再放大頁面看一下漸變,就可以發現每個漸變的高度和html的高度是一致的,而html的高度則是body的默認margin撐開

  于是開始設置

  * {

  margin: 0;

  padding: 0;

  }

  同樣,如果漸變給html設置的,也不會作用到瀏覽器上

  說明瀏覽器并不會把漸變色據為己有,那如果想要設置全屏漸變,就需要用到我們文章開頭說到的

  html, body { height: 100%; }

看完了這篇文章,相信你對“html中的body沒有高度設置背景色為什么可以全屏顯示”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

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

AI

丘北县| 湟源县| 新乐市| 那曲县| 康定县| 新建县| 老河口市| 德州市| 万安县| 张家界市| 海安县| 昌平区| 竹北市| 即墨市| 裕民县| 邹平县| 泾阳县| 垦利县| 神农架林区| 马尔康县| 离岛区| 西盟| 灌南县| 宝兴县| 浪卡子县| 鄂托克前旗| 临颍县| 鄢陵县| 吴川市| 湛江市| 金门县| 浙江省| 房山区| 湟源县| 襄樊市| 广德县| 台北市| 固始县| 鸡泽县| 平南县| 龙胜|