【问题标题】:Force change entire background color ignoring div's (HTML, CSS)强制更改整个背景颜色,忽略 div(HTML、CSS)
【发布时间】:2021-12-08 14:20:22
【问题描述】:

我的网站有多个部分。我需要更改并覆盖每个部分的颜色以使其变为黑色。所以我有body 标签,我试图通过css 方面的标签来做到这一点。我将整个身体的背景颜色强制为黑色,就像这样。

body {
  background-color: #000;
}

但它没有用。它只会更改未包含在其自己的 div 或部分中的任何内容的背景。我正在尝试的可能吗?

【问题讨论】:

  • 您能否再显示一些代码。例如,这些部分的样式首先是如何设置的?
  • 您应该可以通过组合选择器来完成此操作 (developer.mozilla.org/en-US/docs/Web/CSS/…)
  • 背景颜色没有被继承。默认背景颜色为transparent。如果要更改正文中所有元素的背景颜色,请使用全局选择器:body > * { background-color: black; }
  • @tacoshy 只要某些元素类型/类不更改背景颜色(这就是我要求更多代码的原因),它就可以正常工作。如果 OP 很幸运,尽管放置 !important 可能会覆盖它们(只要其他设置当然没有重要)。
  • @AHaworth 当然,需要注意特异性权重。但是,您也说得对,如果没有进一步的细节和清晰性,只能提供可能不完全适用于 OP 案例的一般基本答案。

标签: html css tags frontend background-color


【解决方案1】:

将 HTML 元素想象成层。你有你的主层 (body) 并且你在上面放置了多个元素。如果你改变主层的颜色,它不会影响它上面的元素,因为它们在另一层之上。

你可以说每个元素都将它自己的层添加到 DOM,所以如果你想向下改变一些东西,你必须指定你的需求。

示例

body * {
  background-color: #000;
}

这将影响body标签下没有颜色设置的所有内容。

实现此目的的另一种方法是将所有内容重置为某个值,然后设置所需的元素。

在你的情况下:

* {
  background-color: transparent !important;
}

body * {
  background-color: #000 !important;
}

由于我在所有内容上都使用了!important 标志,因此在设置新值时必须使用它,因为!important 会覆盖特异性。

特异性水平:

Selector Specificity value
* { } 0*
li { } 1 (one element – 0,0,0,1)
body#home div#featured p.text 213 (two id selectors, class selector, 3 HTML selectors – 0,2,1,3)
li:first-line { } 2 (one element, one pseudo-element – 0,0,0,2)
ul li { } 2 (two elements – 0,0,0,2)
#footer *:not(nav) li 23 (one id, two elements – 0,1,0,2)**
ul ol+li { } 3 (three elements – 0,0,0,3)
h1 + *[rel=up] { } 11 (one attribute, one element – 0,0,1,1)
ul ol li.first { } 13 (one class, three elements – 0,0,1,3)
li.last.featured { } 21 (two classes, one element – 0,0,2,1)
style=”” 1000 (one inline styling – 1,0,0,0)
div p.big-text { } 12 (two HTML selectors and a class selector – 0,0,1,2)
#author-name { } 100 (one id selector – 0,1,0,0)
body #blog-list .post p { } 112 (id selector, class selector, 2 HTML selectors – 0,1,1,2)
navbar ul.menu li#first a:not(:visited) { } 133 (id selector, 2 class selectors, 1 pseudo-class, 3 HTML selectors – 0,1,1,2)

您可以阅读更多关于主题here

【讨论】:

  • 我知道您从评论部分复制了您的答案。但是你错过了很多细节。你从来没有提到很可能会导致很多问题的比重。这就是我自己没有给出答案的原因,因为这个话题比那个更复杂。
  • 不幸的是,对于这个问题的要求,如果有其他CSS设置更具体的事物样式,它不会影响body标签下的所有内容。
  • 我的意思是.. 是的,这就是为什么我说你必须指定你的需求.. 很抱歉我没有提到特异性级别,但是一个简单的!important 可以解决问题。仅供参考,我没有从 cmets @tacoshy 复制
  • 也许!important 可以解决这个问题,也许不能。正如@AHaworth 正确评论的那样,可能已经使用了另一个!important。一开始就不应该使用它的众多原因之一。
  • 如果它没有在任何地方使用,在body 上强制它会起作用.. 但同样.. 你可以让一切透明,然后将body 重置为 OP 想要的黑色
猜你喜欢
  • 1970-01-01
  • 2015-02-20
  • 2023-03-26
  • 1970-01-01
  • 1970-01-01
  • 2019-02-06
  • 1970-01-01
  • 2011-08-16
  • 1970-01-01
相关资源
最近更新 更多