为什么 HTML/Body 背景色会影响浏览器背景色?
为什么 html/body 背景色影响浏览器界面
众所周知,body 标签通常是 css 控制的最高节点。当为 body 设置背景色时,整个浏览器的背景色也会改变,即使 body 的大小不足以覆盖浏览器窗口。
有趣的是,如果此时为 html 标签也设置背景色,浏览器的背景色将从 body 的颜色变为 html 设置的颜色。这是为什么呢?
根据 w3c 规范,当根元素为 html 或 body 元素,且 html 元素的 background-image 属性为 none,background-color 属性为透明时,浏览器会从根元素的子元素(即第一个 body 元素)中获取背景属性的计算值,并将其视为根元素的属性值。这意味着浏览器会优先使用 body 元素的背景属性值。
示例:
- 示例一:仅为 body 设置背景色,外边距和边框
body { background: #069; margin: 100px; border: 30px solid #093; }
结果:浏览器背景色变为 #069,而 html 背景为空。
- 示例二:为 body 和 html 设置背景色
html { background: #999; } body { background: #069; margin: 100px; border: 30px solid #093; }
结果:浏览器背景色变为 #999,因为 html 元素具有更高的优先级。
规范建议为 body 元素设置画布背景,而不是 html 元素。这可以避免背景色级联的不一致,确保根元素始终具有定义的背景。
以上就是为什么 HTML/Body 背景色会影响浏览器背景色?的详细内容,更多请关注其它相关文章!