栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > Html/CSS > CSS教程

低权重原则——避免滥用子选择器

CSS教程 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

低权重原则——避免滥用子选择器

CSS的选择符是有权重的,当不同选择符的样式设置有冲突时,会采用权重高的选择符设置的样式。

如果CSS选择符权重相同,那么样式会遵循就近原则,哪个选择符最后定义,就采用哪个选择符的样式。

如果忽略了CSS选择符权重,会产生意想不到的小麻烦。

需求与方案

复制代码代码如下:

#test { font-size: 14px; }

CSS 选择符权重很重要



现在需要将“很重要”三个字设置为红色,我们的做法如下:

方案一,利用子选择器

复制代码代码如下:

#test { font-size: 14px; }
#test span { color: red; }

CSS 选择符权重很重要



方案二,新建class

复制代码代码如下:

#test { font-size: 14px; }
.red { color: red; }

CSS 选择符权重很重要



很多工程师推荐使用方案一,因为使用子选择器可以避免新增class,让HTML代码更简洁。这么考虑是有道理的,但如果这时需求有变化,需要添加新的文字进来。

改变需求

复制代码代码如下:

#test { font-size: 14px; }
#test span { color: red; }

CSS 选择符权重很重要, 我们要小心处理



要求将‘小心处理’设置为绿色,我们可能会这样做。

复制代码代码如下:

#test { font-size: 14px; }
#test span { color: red; }
.green { color: green; }


CSS 选择符权重很重要, 我们要小心处理



本以为‘小心处理’会设置为绿色,但被权重更高的#test span设置为红色。子选择器在无意中影响到了我们新添加的代码。如果想要达到我们的预期,重写代码如下

复制代码代码如下:

#test { font-size: 14px; }
#test span { color: red; }
#test .green { color: green; }


CSS 选择符权重很重要, 我们要小心处理



而如果使用方案二,情况会怎么样呢

复制代码代码如下:

#test { font-size: 14px; }
.red { color: red; }
.green { color: green; }

CSS 选择符权重很重要,我们要小心处理



因为没有子选择器,所以我们给新添加的代码挂上新的class,就可以顺利地完成样式设置了。

小结
使用子选择器,会增加CSS选择符的权重,CSS选择符权重越高,样式越不容易被覆盖,越容易对其他选择符产生影响。所以,除非确定HTML结构非常稳定,不会再修改了,否则尽量不要使用子选择器。为了保证样式容易被覆盖,提高可维护性,CSS选择符需要保证权重尽可能低。

低权重原则——避免滥用子选择器
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/217558.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号