美文网首页
CSS 三大特性

CSS 三大特性

作者: 组团学 | 来源:发表于2020-06-01 16:46 被阅读0次

CSS的三个特性是指层叠性、继承性以及优先级。

一、CSS层叠性

  • 说明

    层叠性是多种CSS样式的叠加,是浏览器处理样式冲突的方式。在HTML中对于同一个元素可以有多个CSS样式存在,当有相同权重的样式存在时,会根据这些样式出现的先后顺序来决定,处于最后面的CSS样式将会覆盖前面的CSS样式。

  • 举例

    下面代码,出现一个div 标签指定了相同样式不同值的情况,这就是样式冲突。

    div{
        color:red;
    }
    div{
        color:blue;
    }
    
  • 原则

    通常出现样式冲突,会按CSS书写的顺序,以最后的样式为准。

    1. 样式不冲突,不会层叠。
    2. 样式冲突,遵循就近原则。 长江后浪推前浪,后面样式盖前面。

二、CSS继承性

  • 说明

    简单的理解为—“子承父业“,是指子标签会继承父标签的==某些==样式,如文本颜色和字号。想要设置一个可继承的属性,只需将它应用于父元素即可。

  • 举例

    <style>
        div{color:pink;font-size:20px;}
    </style>
    <div>
        <span>
            我是什么颜色的?
        </span>
    </div>
    
  • 注意

    1. 合理使用继承可以简化代码,降低CSS样式的复杂性。对于字体、字号、颜色、行距等==文本类属性==具有继承性,都可以在body中统一设置,然后影响文档中所有文本。
    2. 但是,并不是所有的CSS属性都可以继承,如边框、外边距、内边距、背景、定位、元素高度等==与块级元素相关的==属性都不具有继承性。

三、CSS优先级

在复杂CSS样式表,往往并不是相同样式不同值的堆叠这么简单,经常出现两个或多个不同样式规则应用在同一元素上,这时到底采用哪个样式呢?这就是典型的CSS优先级问题。

处理优先级问题,就是考虑样式权重的高低。这里先给大家介绍一些特殊的情况:

  1. ==继承样式的权重为0。==也就是说,在嵌套结构中,无论父元素样式权重多大,子元素继承时,应用在子元素上的权重都为0,即子元素定义的样式会覆盖所有继承来的样式。
  2. ==行内样式优先。==应用style属性的元素,其行内样式的权重非常高,可以理解为远大于100。总之,他拥有比上面提高的选择器都大的优先级。
  3. 权重相同时,CSS遵循就近原则。也就是说靠近元素的样式具有最大的优先级,或者说排在最后的样式优先级最大。
  4. CSS定义了一个!important命令,该命令被赋予最大的优先级。也就是说不管权重如何以及样式位置的远近,!important都具有最大优先级。

CSS特殊性

  • 说明

    或称非凡性,是需要用一套计算公式来去计算CSS的权重。CSS的权重是一个衡量CSS值优先级的一个标准,规则如下:

    用一个四位的数字串(CSS2是三位)来表示,更像四个级别,值从左到右,左面的最大,一级大于一级,数位之间没有进制,级别之间不可超越。

  • 权重比较

    选择器的权重 0,0,0,0
    一个标签(元素)选择器权重 0,0,0,1
    一个类,伪类选择器权重 0,0,1,0
    一个ID选择器权重 0,1,0,0
    一个行内样式权重 1,0,0,0
    一个!important权重 我是王者我最大
  • 权重的叠加

    举例 权重
    div ul li 0,0,0,3
    .nav ul li 0,0,1,2
    a:hover 0,0,1,1
    .nav a 0,0,1,1
    #nav p 0,1,0,1
  • 注意

    1. 继承的权重为 0。
    2. 数值之间没有进制计算,比如: 0,0,0,5 + 0,0,0,5 =0,0,0,10 而不是 0,0, 1, 0, 所以不会存在10个div等于一个类选择器的状况。
    3. 权重是用来计算优先级的,层叠是来表现优先级的。
  • 总结优先级

    !important>行内样式> ID 选择器>类(伪元素、伪类、属性)选择器>元素选择器>通用选择器

    1. 使用了 !important声明的规则。
    2. 内嵌在 HTML 元素的 style属性里面的声明。
    3. 使用了 ID 选择器的规则。
    4. 使用了类选择器、属性选择器、伪元素和伪类选择器的规则。
    5. 使用了元素选择器的规则。
    6. 使用了通配符的规则。
    7. 同一类选择器则遵循就近原则。

相关文章

  • CSS的三大特性总结(深入理解css权重)

    【目录】 css的三大特性层叠性特性说明原理DEMO继承性优缺点重点DEMOhtml代码css代码优先级css特殊...

  • CSS 特性

    继承性 给父元素设置一些属性, 子元素也可以使用, 这个我们就称之为继承性 1.并不是所有的属性都可以继承, 只有...

  • CSS特性

    继承 CSS的一些特性,最常见的就是继承,CSS的有些属性是可以继承的,如果没有样式,则会继承父标签样式。比如co...

  • CSS 特性

    层叠性 样式冲突,遵循就近原则 样式不冲突,不会层叠 结果为红色25px的:Hello World 继承性 子标签...

  • CSS特性

    CSS属性的继承 CSS中有些属性是可继承的,何为属性的继承?一个元素如果没有设置某属性的值,就会跟随父元素的值当...

  • CSS特性

    Display - 块和内联元素 块元素是一个元素,占用了全部宽度,在前后都是换行符。内联元素只需要必要的宽度,不...

  • CSS特性

    一、CSS3 图像的背景 背景图片设定 backgroundCSS允许应用纯色作为背景,也允许使用背景图像创建相当...

  • CSS相关文章

    前端面试之 CSS3 新特性 除了 HTML5 的新特性,CSS3 的新特性也是面试中经常被问到的。如何用 js ...

  • CSS 常见知识点记录-flex布局、css特性、positio

    一、CSS特性、块级元素、行内级元素、display 1、CSS的两大特性是什么?并解释其中含义? 【继承】 【层...

  • css基础04- css三大特性

    css三个特性 继承 ,层叠 ,优先级 是我们学习CSS 必须掌握的三个特性。 继承性 所谓继承性是指书写CSS样...

网友评论

      本文标题:CSS 三大特性

      本文链接:https://www.haomeiwen.com/subject/ereszhtx.html