- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在阅读特异性,坦率地说,令我惊讶的是我之前没有正确地了解这一点,因为我亲眼目睹了如果 CSS 声明错误,特异性会带来的问题方式。
因此,我一直在对该主题进行一些研究,现在我了解了计算特异性的规则。然而,在我的发现过程中,我留下了三个问题,我希望你们能帮助我解决这些问题。
首先,在涉及 CSS 特异性时,我注意到 one source在计算中包括伪元素,而 another告诉您将它们排除在计算之外。这纯粹是一个可选的东西,还是我应该包括它们?
其次,我应该在标识符之上声明类有什么具体原因吗?例如,我已经对我的开发 CSS 文件进行了分段,在“页脚”部分,我有 #footer
、#footer-container
、.grid
和 .one-third
,按此顺序声明。这完全没问题,还是我应该调换它们?定义的规则如下,以表明这两个类不包含任何冲突的属性:
#footer {
background: #e4e4e4;
border-top: 1px solid #eeeeee;
border-bottom: 1px solid #666666;
overflow: hidden;
padding-bottom: 1em;
width: 100%;
}
#footer-container {
margin: 0 auto;
width: 100%;
min-width: 1000px;
}
.grid {
margin-right: 2.1%;
float: left;
display: inline;
position: relative;
}
.one-third {
width: 31.9%;
}
最后,只是一个关于按字母顺序列出 CSS 属性的快速问题。我完全理解这是可选的,但是以我对上面的 #footer
的声明为例,是否有对 border
、margin
或padding
,如字母顺序(bottom; left; right; top
),或声明为简写形式(top; right; bottom; left
)?
非常感谢!
最佳答案
Firstly, when relating to CSS specificity, I've noticed that one source includes pseudo elements in the calculation, while another tells you to leave them out of the calculation. Is this purely an optional thing, or should I include them?
这对我来说是个新闻;看起来 CSS2.1 之前的伪元素原本应该在计算选择器特异性时被忽略。将它们排除在计算之外的文章发表于将近十年前,就在 CSS 2 级重构的中间。这是 1998 CSS2 recommendation 的内容说(作为引用,在那篇文章中也被引用,但它链接到的 URL 重定向到规范的最新修订版,其中发生了更改):
A selector's specificity is calculated as follows:
- count the number of ID attributes in the selector (= a)
- count the number of other attributes and pseudo-classes in the selector (= b)
- count the number of element names in the selector (= c)
- ignore pseudo-elements.
在CSS2.1 ,以及最新的Selectors standard ,伪元素在计算特异性时必须像普通类型选择器一样计算。
也许更奇怪的是 CSS1就特异性而言,伪元素的规则与当前标准相同:
Pseudo-elements and pseudo-classes are counted as normal elements and classes, respectively.
这让我相信 CSS2.0 中的变化最终在 CSS2.1 中被逆转,因此它不会破坏碰巧依赖于行为的现有(遗留)样式表,和/或因为它根本没有不包含伪元素是有意义的,因为您可以像对待实际元素一样向它们应用样式。
Secondly, is there any specific reason why I should declare classes above identifiers? For instance, I've already sectioned my development CSS file, and in the 'footer' section, I have
#footer
,#footer-container
,.grid
and.one-third
, declared in this order. Is this perfectly fine, or should I switch them around?
将类放在 ID 之前应该没有区别,只要您的两个类遵循它们所在的顺序,您的两个 ID 也是如此。即使假设所有这些规则恰好匹配相同的元素,对于需要覆盖的任何属性,ID 也应优先于类。
Lastly, just a quick question about listing CSS properties in alphabetical order. I fully understand that this is optional, but using my declaration for
#footer
above as an example, is there any preference forborder
,margin
orpadding
, as in alphabetical (bottom; left; right; top
), or declared as written in shorthand (top; right; bottom; left
)?
如果您单独声明普通属性,则完全取决于您希望如何对它们进行排序。为了简单起见,我当然会遵循速记已经列出的顺序。
仅供引用,速记中的顺序是按原样排列的,因为如果您按字面意思将点连接起来,顺序实际上是从顶部开始顺时针。
关于CSS 特异性 - 定义类和 ID,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21455250/
我有一个名为 main.css 的 css 文件和另一个名为 style.css 的文件。我怎样才能在 main.css 中做到这一点? .someClass { //apply rules to
在更新我的 css 之前,我在 Login.css 中有以下内容: body { background-image: url('./pictures/fond.png'); bac
我的 share point 2013 核心 css 和我的 css 之间存在 css 冲突。所以我想把我所有的类都放在 div #s4-workspace 下但是我搜索了一种方法来将所有类分组到这个
我知道您可以覆盖 jsp 页面从 jsp 包含 CSS 文件(即全局 CSS 文件)继承的 CSS 属性。 但是,如果元素中的某个属性弄乱了特定页面,而我不想只使用内联 CSS 在该页面中使用它怎么办
我刚刚发现了 initial-scale 元属性。 以前,我一直在使用 default.css 来定义我所有的样式和大小(用于字体和元素),以便它们在桌面计算机的屏幕上显示得很好。然后,如果您使用的是
我正在尝试使用 LESS CSS 来编写我的 CSS。我已经按顺序导入了 style.less 和 less.js 文件。 现在我想提取 LESS 生成的 CSS。有什么办法可以做到吗?我不想使用脚本
我想知道是否有任何一种软件可以读取大量内联样式中的 HTML 文档并将所有这些样式转换为外部 css 文件。如果只有一页,我可以手动完成。但是有100页。有人有想法吗? 最佳答案 就像有人说的那样,“
当我想从 Styled Components 迁移到 CSS Modules 时,出现了以下问题。 假设我有以下样式组件,它接受动态参数 offset和一个动态 CSS 字符串 theme : con
有没有办法将 CSS 类定义为与另一个类相等?例如,如果我有一个类: .myClass{ background-color: blue; } 有没有一种方法可以将第二个类定义为与 myClas
我正在尝试制作一组按钮,这些按钮贴在页面底部并且由固定的空间隔开。我正在使用 angularJS 的 ng-repeat 指令通过 ajax 请求获取数据,然后我用它来显示按钮。 我的问题在于让按
浏览器是否在加载 CSS 文件时解析 CSS?还是在整个 CSS 文件被浏览器下载后才进行解析?不同浏览器的做法有区别吗?我在哪里可以找到这种底层信息? 这个问题不是 Load and executi
这个问题在这里已经有了答案: Can a CSS class inherit one or more other classes? (29 个答案) 关闭 3 年前。 标题有点乱,我给大家看一下。假
我遇到了最奇怪的问题...... 在最简单的形式中,我有一个包含以下内容的 index.html 文件: (在尝试确定根本原因的过程中,我已经大大减少了它) 当我查看页面的源代码时,我得到以下信息:
我正在使用 Mindscape Workbench 来最小化我的 scss 文件。我的页面设置为使用 *.min.css 文件。在随机时间,min 文件不会与系统的其余部分一起发布。 我有很多 css
请告诉我 CSS 框架和 CSS 网格之间的区别。 最佳答案 CSS 框架也可以是 CSS 网格框架。 CSS 网格框架用于构建 CSS 布局。有一些框架除了构建布局还有其他用途,例如 Hartija
我有无法从页面中删除或更改的 original.css 文件。原始.css table { border-collapse: collapse; border-spacing: 0;
我以前使用 bootstrap css import 很好。 但是我正在尝试使用 CSS 模块,所以我添加了几行。 { test: /\.css$/, use:
有没有办法在 css 选择器中创建一个 css 组。 例如: .SectionHeader { include: .foo; include: .bar; include: .
今天我学习了 CSS 中的两个概念,一个是 CSS 定位(静态、相对、绝对、固定),另一个是 CSS Margin,它定义了元素之间的空间。 假设我想移动一个元素,这是最好的方法吗?因为这两个概念似乎
var paths = { css: './public/apps/user/**/*.css' } var dest = { css: './public/apps/user/css/' } /
我是一名优秀的程序员,十分优秀!