CSS三大特性之层叠性

news2025/1/11 4:22:28

CSS的三个特性:层叠性,继承性,优先级

层叠性:

相同选择器给设置相同的样式,此时一个样式就会覆盖(层叠)另一个冲突的样式,层叠性主要解决样式冲突的问题。

层叠性原则:

样式冲突,遵循的原则是就近原则,那个样式离结构近,就执行那个样式

样式不冲突,不会层叠

举例:

<head>
    <style>
        div{
            color:aquamarine;
            font-size: 40px;
        }
        div{
            color:blue;
        }
    </style>
</head>
<body>
    <div>层叠样式</div>
</body>

显示如下:

color被覆盖而font-size并没有被覆盖

在这里插入图片描述

继承性:

CSS中的继承:子标签会继承父标签的某些样式,如文本的颜色和字号。

举例:

<head>
    <style>
        div{
            color:aquamarine;
            font-size: 20px;
        }
    </style>
</head>
<body>
    <div>
        <p>我是div的子标签</p>
    </div>
</body>

显示如下:

在style中,我们并没有给p标签设置任何的属性,但由于它是div标签的子标签,所以他最终显示的效果是div的样式

在这里插入图片描述通过我们之前所讲的调试工具,它也能告诉我们p的样式是继承与div标签

在这里插入图片描述

继承性的优点:

1:恰当的使用继承可以简化代码量,降低CSS样式的复杂性

2:子元素可以继承父元素的样式(text-,font-,line-这些元素开头的属性都可以继承,以及color属性)

行高的继承性:

我们先来回忆一下综合设置字体样式的语法:

p{
font:font-style font-weight font-size/line-height font-family;
}

通过之前的学习我们知道,行高的单位是px,但行高也可以不带单位,但是不带单位并不是直接把px去掉,而是改变一下表示方法。

举例:

之前的写法:

div {
            color: blue;
            font: 15px/30px 宋体;
}

不带单位:

 div {
            color: blueviolet;
            font: 15px/2 宋体;//表示行高为当前文字大小的2倍,也就是30px
}

以上两种书写均正确!

如果子元素没有设置行高,则会继承父元素的行高

举例:

<head>
    <style>
        div {
            color: blueviolet;
            font: 15px/2 宋体;
        }
        p{
            color:aquamarine;
            font-size:20px;
        }

    </style>
</head>
<body>
    <div >我是div1中的文字
        <p>我是p标签</p>
    </div>
</body>

显示如下:

我们并没有给p标签指定行高,仅仅是指定了它的文字大小,那么它就会继承父元素div的行高,此时的行高大小为p标签文字的大小×2

在这里插入图片描述而这样写的好处就在于我们能够通过子元素的文字大小自动调整它的行高

优先级:

当同一个元素指定多个选择器,就会有优先级的产生

选择器相同的情况下,则执行层叠性

就近原则!!

选择器不同,则根据选择器权重执行

在这里插入图片描述上表中的选择器权重由上到下依次增大,选择器权重越大,优先级越高

举例:

<head>
    <style>
         .div1{
            color:aquamarine;
            font-size:20px;
        }
        div {
            color: blueviolet;
            font: 15px/2 宋体;
        }
    </style>
</head>
<body>
   <div class="div1">早上好</div>
</body>

显示如下:

在这里插入图片描述其它的都是一样的方法,大家可以自行写代码体会一下,这里我们重点说一下最后一个选择器的用法:

!important选择器:

在选择器中,它的权重是最大的,可以理解为它能够强制性的将某个权重较低选择器中的某个样式显示出来,只需要在该样式后面+!important

举例:

<head>
    <style>
         .div1{
            color:aquamarin ;
            font-size:10px;
        }
        div {
            color: blueviolet !important;
            font-size:  50px;
        }
    </style>
</head>

<body>
   <div class="div1">早上好</div>
</body>

显示如下:
在这里插入图片描述类选择器的权重大于标签选择器,所以此时应该显示的是类选择器中指定的样式,但由于在标签选择器的color属性后面,使用了!important,所以字体的颜色显示出来的是标签选择器中的样式,并非类选择器中的样式。

但是需要注意的是,标签选择器中的font-size属性并没有通过!important强制指定,因此字体的大小还是类选择器中指定的大小,!important只能用来指定单个的属性。

优先级----小tips:

1:权重是由4组数字组成,但是不会有进位

2:等级判断从左到右,如果某一位数值相同,则判断下一位

3:继承的权重是0,如果该元素没有被选中,不管父元素权重是多少,子元素得到的权重都是0

举例:

<head>
    <style>
       #div1{
        color:chartreuse;
       }
       p{
        color:darksalmon;
       }
    </style>
</head>
<body>
   <div id="div1">早上好
    <p>我是p标签</p>
   </div>
</body>

显示如下:

为什么p标签中的文字并没有像显示它的父类id选择器中的效果呢?

原因就是我们上述所说的,子元素继承的权重为0, 即使父元素的权重很高,但是在子元素这里都是0,因此p标签中的文字显示的效果为元素选择器中的样式

在这里插入图片描述
关于优先级,还有一个特殊的标签-----a标签:

下述实例中,我们对body部分进行了样式的设置:

<head>
    <style>
       body{
        color:darkgreen;
       }
    </style>
</head>
<body>
   <div id="div1">早上好
    <p>我是p标签</p>
   </div>
   <a href="#">我是超链接</a>
</body>

显示如下:

在这里插入图片描述但是显示效果中a标签的文字依旧是绿色,查看style,我们也没有对a标签进行额外的样式设计呀

原因就是a标签被浏览器默认的设置为蓝色的带下划线的样式,所以即使没有对它设置新的样式,他也不会继承body的样式。

如果不想a标签显示浏览器默认的样式,那么我们可以通过元素选择器对其设置新的样式

举例:

<head>
    <style>
       body{
        color:darkgreen;
       }
       a{
        color:chocolate;
       }
    </style>
</head>
<body>
   <div id="div1">早上好
    <p>我是p标签</p>
   </div>
   <a href="#">我是超链接</a>
</body>

显示如下:

在这里插入图片描述

权重的叠加问题:

权重的叠加一般出现在复合选择器中,这里就需要涉及权重的计算问题

举例:

   <head>
        <style>
        /*ul li权重计算:0,0,0,1+0,0,0,1=0,0,0,2	2*/
           ul li{
            color:darkolivegreen;
           }
           /*li权重是:0,0,0,1	1*/
           li{
            color:brown;
           }
           /* .nav li 权重计算:0,0,1,0+0,0,0,1=0,0,1,1		11*/
           .nav li{
            color:aquamarine;
           }
        </style>
    </head>
    <body>
       <ul class="nav">
        <li>早上好</li>
        <li>中午好</li>
        <li>晚上好</li>
       </ul>
    </body>

取权重最大的值的样式进行显示

显示如下:
在这里插入图片描述注意:权重在叠加的过程中,不要进位

上述我们所举的例子涉及的选择器个数较少,但是当选择器的个数比较大时,就会出现叠加之后,最后一位变成了10,正确写法即为:0,0,0,10请记住,无论变成几十还是几百,第四位的数值都不能向上进一位,因为权重本身就是由4位构成的,我们不能加着加着把标签选择器变成了类选择器,这是不对的。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/54122.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Deadlock found when trying to get lock; try restarting transaction

报错详情 Error updating database. Cause: com.mysql.cj.jdbc.exceptions.MySQLTransactionRollbackException: Deadlock found when trying to get lock; try restarting transaction The error may involve com.iss.cms.fdrb.common.dao.entity.InterfaceQueue.updateInt…

数据库、计算机网络,操作系统刷题笔记6

数据库、计算机网络&#xff0c;操作系统刷题笔记6 2022找工作是学历、能力和运气的超强结合体&#xff0c;遇到寒冬&#xff0c;大厂不招人&#xff0c;可能很多算法学生都得去找开发&#xff0c;测开 测开的话&#xff0c;你就得学数据库&#xff0c;sql&#xff0c;oracle&…

RK3588平台开发系列讲解(Thermal篇)Thermal介绍及用法

平台内核版本安卓版本RK3588Linux 5.10Android12🚀返回专栏总目录 文章目录 一、Thermal介绍二、相关代码路径三、用户态接口说明四、常见问题4.1 关温控4.2 获取当前温度沉淀、分享、成长,让自己和他人都能有所收获!😄 📢本篇将介绍Thermal的相关内容及调试手段。 一…

环境配置之终端WezTerm

前言 其实是在复习的过程中发现终端非常别扭&#xff0c;了解了一些大佬的使用方式后&#xff0c;尝试使用一个多平台的终端应用。 环境配置 之前在MAC上使用过的终端包括ZenTermLite和Item2&#xff0c;这次使用一个跨平台的终端WezTerm&#xff01; 缺点就是自定义的地方太…

JUC并发编程第七篇,volatile凭什么可以保证可见性和有序性?我们该如何正确使用它?

JUC并发编程第七篇&#xff0c;volatile凭什么可以保证可见性和有序性&#xff1f;我们该如何正确使用它&#xff1f;一、volatile的作用是什么&#xff1f;二、什么是内存屏障&#xff1f;三、四大内存屏障指令源码解析&#xff01;四、volatile如何通过内存屏障保证可见性和有…

Spring MVC数据绑定和表单标签的应用(附带实例)

为了让读者进一步学习数据绑定和表单标签&#xff0c;本节给出了一个应用范例 springMVCDemo04。该应用中实现了 User 类属性和 JSP 页面中表单参数的绑定&#xff0c;同时在 JSP 页面中分别展示了 input、textarea、checkbox、checkboxs、select 等标签。 应用的相关配置 在…

解析csv文件,读取百万级数据

最近在处理下载支付宝账单的需求&#xff0c;支付宝都有代码示例&#xff0c;功能完成还是比较简单的&#xff0c;唯一的问题就在于下载后的文件数据读取。账单文件可大可小&#xff0c;要保证其可用以及性能就不能简单粗暴的完成开发就行。 文件下载是是csv格式&#xff0c;此…

干货|成为优秀软件测试工程师的六大必备能力

“软件吞噬世界”、“软件定义一切”。随着软件行业的迅速发展&#xff0c;保障软件质量的关键环节——软件测试也变得越来越重要。而执行测试工作的测试工程师&#xff0c;便是软件质量的把关者。 测试工程师早在2005年就被劳动和社会保障部门列入第四批新职业中。经过短短几…

文件批量从gbk转成utf8的工具

工具名&#xff1a;GB/BIG5/UTF-8 文件编码批量转换程序 下载地址&#xff1a; https://www.wenjiangs.com/wp-content/uploads/2018/05/GB2UTF8.zip 程序功能&#xff1a;将 GB、BIG5、UTF-8 文件相互转换&#xff0c;方便的批量处理能力&#xff0c;主要用于网站文件编码方式…

单商户商城系统功能拆解41—应用中心—用户储值

单商户商城系统&#xff0c;也称为B2C自营电商模式单店商城系统。可以快速帮助个人、机构和企业搭建自己的私域交易线上商城。 单商户商城系统完美契合私域流量变现闭环交易使用。通常拥有丰富的营销玩法&#xff0c;例如拼团&#xff0c;秒杀&#xff0c;砍价&#xff0c;包邮…

R语言进行相关矩阵分析及其网络可视化

数据准备 # 选择感兴趣的列 mydata <- mtcars %>% select(mpg, disp, hp, drat, wt, qsec) # 添加一些缺失值 mydata$hp[3] <- NA # 检查数据 head(mydata, 3) ## mpg disp hp drat wt qsec ## Mazda RX4 21.0 160 110 3.90 2.62 16.5 ## Ma…

基于WiFi小车控制板的单片机小系统原理图

小系统&#xff0c;指的是的用少的元件组成的单片机可以工作的系统。一般在设计小系统的时候分为这四种必要的电路&#xff0c;分别是1、电源供电电路;2、单片机复位电路;3、时钟振荡电路;4、程序的下载接口电路。这次基于我们研发的WiFi小车51核心控制板的小系统原理图来讲一下…

uni-app实现支付及项目打包上传

本文主要介绍uni-app项目中如何实现支付功能&#xff08;支付宝支付、微信支付&#xff09;&#xff0c;及项目如何打包上传。 一、实现支付 前置工作&#xff0c;项目要实现支付功能&#xff0c;首先要在根目录manifest.json文件内App模块配置中进行设置。 其中&#xff0c;a…

机构运动学分析

背景介绍 空间机构具有结构紧凑、运动灵活等特点&#xff0c;在航空航天、精密仪器以及工业设备等领域具有广泛的应用。调研发现&#xff0c;机械臂一般采用伺服电机作为动力源&#xff0c;通过空间连杆驱动末端执行器&#xff0c;大大的减轻了工人的劳动强度。本节中主要是针对…

iconfont小图标从下载到引入到vue项目中的详细教程

地址&#xff1a;iconfont-阿里巴巴矢量图标库 iconfont小图标下载&#xff1a; &#xff08;1&#xff09;查找图标 在搜索框直接文字搜索或者看下面的小图标库&#xff0c;找想要的&#xff0c;每个小图标库都有一个名字&#xff0c;比如&#xff1a;“阿里云官网”&#x…

Vue2中$set的使用

一、什么场景下使用$set set为解决Vue2中双向数据绑定失效而生&#xff0c;只需要关注什么时候双向数据绑定会失效就可以了。 例如&#xff1a; 1.利用数组中某个项的索引直接修改该项的时候 arr[indexOfItem] newValue 2.直接修改数组的长度的时候 arr.length newLength …

gRPC学习笔记(一)

文章目录gRPC初学思维导图异步多函数多类的调用grpc初学总结&#xff1a;杂项gRPC初学思维导图 异步多函数多类的调用 一个类里有多个方法时&#xff0c; 两种方法&#xff1a; 定义不同的类&#xff08;推荐&#xff0c;只管自己的实现&#xff0c;换了请求类型&#xff0c;…

在linux系统上看全世界新闻 -- Clinews的使用详解

一. Clinews介绍 Clinews 和 InstantNews 类似&#xff0c;都是 Linux 命令行下的新闻客户端&#xff0c;安装及配置 Clinews 后就可以在 Linux 命令行下阅读新闻及头条新闻了&#xff0c; 当然还有博客新闻&#xff0c;不需要安装 GUI 应用或移动应用&#xff0c;轻松在 Linu…

值得收藏的30道Python练手题(附详解)

今天给大家分享30道Python练习题&#xff0c;建议大家先独立思考一下解题思路&#xff0c;再查看答案。 1.已知一个字符串为 “hello_world_yoyo”&#xff0c;如何得到一个队列 [“hello”,”world”,”yoyo”] &#xff1f; 使用 split 函数&#xff0c;分割字符串&#xf…