您现在的位置是:网站首页> 编程资料编程资料
低权重原则——避免滥用子选择器CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
2021-09-07
650人已围观
简介 CSS的选择符是有权重的,当不同选择符的样式设置有冲突时,会采用权重高的选择符设置的样式,经验告诉我,低权重原则——避免滥用子选择器,感兴趣的朋友可以参考本文,希望对大家有所帮助
CSS的选择符是有权重的,当不同选择符的样式设置有冲突时,会采用权重高的选择符设置的样式。
如果CSS选择符权重相同,那么样式会遵循就近原则,哪个选择符最后定义,就采用哪个选择符的样式。
如果忽略了CSS选择符权重,会产生意想不到的小麻烦。
需求与方案
现在需要将“很重要”三个字设置为红色,我们的做法如下:
方案一,利用子选择器
方案二,新建class
很多工程师推荐使用方案一,因为使用子选择器可以避免新增class,让HTML代码更简洁。这么考虑是有道理的,但如果这时需求有变化,需要添加新的文字进来。
改变需求
要求将‘小心处理’设置为绿色,我们可能会这样做。
本以为‘小心处理’会设置为绿色,但被权重更高的#test span设置为红色。子选择器在无意中影响到了我们新添加的代码。如果想要达到我们的预期,重写代码如下
而如果使用方案二,情况会怎么样呢
因为没有子选择器,所以我们给新添加的代码挂上新的class,就可以顺利地完成样式设置了。
小结
使用子选择器,会增加CSS选择符的权重,CSS选择符权重越高,样式越不容易被覆盖,越容易对其他选择符产生影响。所以,除非确定HTML结构非常稳定,不会再修改了,否则尽量不要使用子选择器。为了保证样式容易被覆盖,提高可维护性,CSS选择符需要保证权重尽可能低。
低权重原则——避免滥用子选择器
如果CSS选择符权重相同,那么样式会遵循就近原则,哪个选择符最后定义,就采用哪个选择符的样式。
如果忽略了CSS选择符权重,会产生意想不到的小麻烦。
需求与方案
复制代码
代码如下:CSS 选择符权重很重要
现在需要将“很重要”三个字设置为红色,我们的做法如下:
方案一,利用子选择器
复制代码
代码如下:CSS 选择符权重很重要
方案二,新建class
复制代码
代码如下:CSS 选择符权重很重要
很多工程师推荐使用方案一,因为使用子选择器可以避免新增class,让HTML代码更简洁。这么考虑是有道理的,但如果这时需求有变化,需要添加新的文字进来。
改变需求
复制代码
代码如下:CSS 选择符权重很重要, 我们要小心处理
要求将‘小心处理’设置为绿色,我们可能会这样做。
复制代码
代码如下:
CSS 选择符权重很重要, 我们要小心处理
本以为‘小心处理’会设置为绿色,但被权重更高的#test span设置为红色。子选择器在无意中影响到了我们新添加的代码。如果想要达到我们的预期,重写代码如下
复制代码
代码如下:
CSS 选择符权重很重要, 我们要小心处理
而如果使用方案二,情况会怎么样呢
复制代码
代码如下:CSS 选择符权重很重要,我们要小心处理
因为没有子选择器,所以我们给新添加的代码挂上新的class,就可以顺利地完成样式设置了。
小结
使用子选择器,会增加CSS选择符的权重,CSS选择符权重越高,样式越不容易被覆盖,越容易对其他选择符产生影响。所以,除非确定HTML结构非常稳定,不会再修改了,否则尽量不要使用子选择器。为了保证样式容易被覆盖,提高可维护性,CSS选择符需要保证权重尽可能低。
低权重原则——避免滥用子选择器
相关内容
- 给表格设置不重叠的边框(单线边框)的2种方法CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- CSS控制图片、表格、背景颜色渐变示例使用CSS改变图片颜色的100种方法(值得收藏)css控制背景示例(css设置背景图片、设置背景颜色)css3实现背景颜色渐变让图片不再是唯一的实现方式纯css实现更改图片颜色的技巧
- css按坐标取背景图示例代码CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- CSS3正方体旋转示例代码css3中transform属性实现的4种功能详解CSS3.0(Cascading Style Sheet) 层叠级联样式表纯CSS3实现div按照顺序出入效果CSS3实现列表无限滚动/轮播效果css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效CSS3实现的侧滑菜单CSS3实现的3D隧道效果用CSS3画一个爱心css3 实现文字闪烁效果的三种方式示例代码六种css3实现的边框过渡效果
- HTML+CSS+JavaScript通过嵌套ul li实现简单的二级菜单使用HTML+CSS实现鼠标划过的二级菜单栏的示例纯CSS实现鼠标滑过显示子菜单的二级菜单效果js+css实现圆角二级菜单jQuery CSS 完美兼容的二级菜单css 实现动态二级菜单
- css3学习心得分享css3中transform属性实现的4种功能详解CSS3.0(Cascading Style Sheet) 层叠级联样式表纯CSS3实现div按照顺序出入效果CSS3实现列表无限滚动/轮播效果css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效CSS3实现的侧滑菜单CSS3实现的3D隧道效果用CSS3画一个爱心css3 实现文字闪烁效果的三种方式示例代码六种css3实现的边框过渡效果
- IE6下div层被select控件遮住的问题解决方法IE中div被视频遮住(用embed来内嵌视频)的解决方法IE7浮层遮挡问题探讨及解决DIV遮罩层如何实现巧用CSS3 border实现图片遮罩效果代码div背景半透明,覆盖整个可视区域的遮罩层效果 div背景半透明 覆盖整个可视区域的遮罩层效果ie6 select无法被div遮盖的bug解决方法利用js+css简单实现半透明遮罩弹窗如何解决IE6/7绝对定位元素神秘消失或被遮挡的方法 css 遮罩样式(支持IE和FireFox)
- input 按钮背景在IE6 IE7中不显示的解决方法input 按钮在IE下显现不一致的兼容问题input 按钮显示差异的解决方法CSS让网页提交input按钮与众不同类型File的Input按钮功能研究关于如何去掉submit按钮背景阴影的解决方法input 背景图片移出 bug解决适合绝大多数电脑用户的老牌实用软件 驱动精灵 2011V5.5.513.2020 绿色
- css3实现背景图片拉伸效果像桌面壁纸一样CSS3实现的全屏背景图片缩小渐变切换效果源码CSS的background属性及CSS3的背景图片设置总结jQuery+CSS3实现鼠标点击背景图片向上拉伸切换特效源码jquery+css3实现的网页背景图片固定内容切换特效源码CSS3对背景图片的裁剪及尺寸和位置的设定方法多重CSS背景动画实现方法示例css实现的鼠标悬停360度背景图片做动画旋转效果css3背景图片透明叠加属性cross-fade简介及用法实例
- display:inline-block的使用示例display:inline-block的使用示例CSS属性display:inline-block用法深入理解display:inline-block的原理分析深入display:inline-blockdisplay:inline | block |inline-block-CSS教程-网页制作-网页教学网兼容性的 inline-block 属性