Css-层叠(样式优先级+选择器优先级+继承)

定义CSS的方式:

样式表优先级:内联样式>内嵌样式>外联样式

内联样式
<div style="background-color:#red">
内嵌样式
<style>div{ background-color:red }</style>
外联样式
<link rel="stylesheet" src="index.css"/>

但是为了减少回流开销,尽量少的使用内联样式,使用内嵌和外联

选择器的类型:

三大类:基本选择器关系选择器伪选择器

CSS选择器
基本选择器
关系选择器
伪选择器
通配符选择器0
类型选择器1
类选择器10
ID选择器100
属性选择器10
后代选择器0
子选择器0
兄弟选择器0
相邻选择器0
伪类选择器10
伪元素选择器1

权重顺序ID选择器>类选择器/伪类选择器/属性选择器>关系选择器/伪元素选择器(优先级为0)
声明了:!important是最大,大于内联

继承:

外观相关的属性会被继承(font-family、color、background-color)
布局相关的属性不能被继承(margin、padding、width、height、border)

伪类选择器:

定义的顺序::link :visited :hover :active(记忆 LVHA love hate)
定义在一个元素上,权重相同 ,当悬浮:hover到未访问:link或已访问:visited元素上的时,会同时触发:link/:visited:hover,如果:link/:visited定义在:hover之后,:hover定义样式被覆盖。
鼠标点击的时候,会有:active:hover两种状态,如果:hover放在:active后面,:active被覆盖

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CSS选择器的优先级是由多个因素决定的。一般情况下,选择器的优先级由其组成部分的权重决定,具体规则如下: 1. 使用!important标记的样式具有最高优先级,会覆盖其他所有样式。 2. 选择器中包含的ID选择器的权重最高,接下来是类选择器和属性选择器,最后是标签选择器。例如,#id选择器的权重高于.class选择器,而.class选择器的权重又高于标签选择器。 3. 组合选择器(如子选择器、后代选择器等)的优先级与组合中各个选择器的优先级相加。例如,div p选择器的优先级高于div选择器。 4. 当具有相同优先级的选择器应用于同一个元素时,后面出现的选择器具有更高的优先级。这意味着后渲染的样式会覆盖先渲染的样式。 为了避免样式冲突和样式覆盖的问题,可以采取以下措施: 1. 确保选择器的权重足够高,以覆盖其他可能的选择器。可以使用ID选择器或!important标记来提高权重,但需要谨慎使用!important,尽量避免滥用。 2. 使用更具体的选择器来定位目标元素,以减少与其他元素的冲突。 3. 避免使用嵌套选择器和通用选择器,这样可以减少选择器的复杂性和权重。 4. 使用样式层叠继承的特性,合理组织样式表的结构,使得样式之间相互独立且易于维护。 通过合理的选择器使用和样式组织,可以有效地解决CSS选择器优先级的问题,避免样式冲突和样式覆盖的情况发生。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [CSS选择器优先级](https://blog.csdn.net/qq_40920910/article/details/122920539)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值