css - 为什么嵌套 CSS 选择器是自下而上应用的?

标签 css css-selectors

据我了解,在嵌套 CSS 规则中,选择器是从最嵌套的选择器应用的,自下而上。例如以下内容:

.foo > .bar .baz{
  ...
}

.baz从页面中选择元素,然后将其限制为 .bar 的后代元素,那么它仅限于 .foo 的子级。 。为什么会这样?我读到这会导致嵌套 CSS 规则效率低下。大多数情况下,我认为自上而下的限制会更有效。

最佳答案

最有效的选择器不需要遍历 - 它只会应用于有问题的元素。

无论是从上往下遍历还是从下往上遍历,都会比不遍历效率低。

自下而上比自上而下更有效,因为您只遍历选择器匹配的位置 - 因此如果当前元素不是 .baz 则无需执行任何操作。如果它是 .baz,则检查 .bar 的祖先并重复,直到满足条件或匹配所有选择器为止。

此外,您正在尝试确定是否向该元素应用一种样式,因此您有一个元素并确定匹配的样式。如果您自上而下地工作,您将进行发散匹配,而不是收敛匹配,即如果您从 .foo 开始,您可能会在样式规则右侧找到许多选择器匹配项 - 所以您最终会得到要检查的匹配元素树。

关于css - 为什么嵌套 CSS 选择器是自下而上应用的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20131264/

相关文章:

html - 有没有办法让 IE6 在遇到 '>' 时优雅地失败?

css - BEM 嵌套命名约定——孙元素

javascript - 如何设置 HTML 选择选项悬停和选定选项效果的样式

css - .class 和第一个 td 之后的 img 选择器

javascript - 从左到右动画 div 宽度

javascript - 在另一个 div 中查找 div 的相对位置(ng-drag-drop)

html - 菜单在 Firefox 中显示不正确

css - 如何从右到左渲染进度元素?

html - 如何删除此搜索框中的多余空间(输入字段和按钮之间)

html - 第 N 个子选择器