css样式表中的样式覆盖顺序

本文详细解释了CSS中样式优先级的规则,包括ID选择器、类选择器及元素选择器之间的优先级关系,以及如何使用!important提高特定样式的优先级。

有时候在写CSS的过程中,某些限制总是不起作用,这就涉及了CSS样式覆盖的问题,如下

<!DOCTYPE html>
<html lang="en">
<head>
    <style>
        #navigator {
            position: absolute;
            background-color: red;
        }

        .current_bg {

            background-color: green;
        }
    </style>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div id="navigator" class="current_bg" > 显示为红色</div>
</body>
</html>

查找一些教材中(w3schools等),只说css的顺序是“元素上的style” > “文件头上的style元素” >“外部样式文件”但对于样式文件中的多个相同样式的优先级怎样排列,没有详细说明。经过测试和继续搜索,得知优先级如下排列

  1. 样式表的元素选择器选择越精确,则其中的样式优先级越高:
id选择器指定的样式 > 类选择器指定的样式 > 元素类型选择器指定的样式

所以上例中,#navigator的样式优先级大于.current_block的优先级,及时.current_block是最新添加的,也不起作用。

  1. 对于相同类型选择器制定的样式,在样式表文件中,越靠后的优先级越高

注意,这里是样式表文件中越靠后的优先级越高,而不是在元素class出现的顺序。比如.class2 在样式表中出现在.class1之后:

<!DOCTYPE html>
<html lang="en">
<head>
    <style>
        .class1 {
            position: absolute;
            background-color: red;
        }

        .class2 {

            background-color: green;
        }
    </style>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div id="navigator" class="class1 class2" > 显示为绿色</div>
</body>
</html>

而某个元素指定class时采用 class="class2 class1"这种方式指定,此时虽然class1在元素中指定时排在class2的后面,但因为在样式表文件中class1处于class2前面,此时仍然是class2的优先级更高。

  1. 如果要让某个样式的优先级变高,可以使用!important来指定:
<!DOCTYPE html>
<html lang="en">
<head>
    <style>
        .class1 {
            background-color: red  !important;
        }

        .class2 {

            background-color: green;
        }
    </style>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div id="navigator" class="class1 class2" > 显示为红色</div>
</body>
</html>

对于一开始遇到的问题,有两种解决方案:

  1. background-color#navigator中拿出来,放到一个class .bg中,而.bg放到.current_bg之前:
<html lang="en">
<head>
    <style>
        #navigator {
            position: absolute;
        }

        .bg {
            background-color: red;
        }

        .current_bg {

            background-color: green;
        }
    </style>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div id="navigator" class="bg"> 显示为红色</div>
</body>
</html>

需要设置为#navigator元素指定class="bg"

  1. 使用!important:
<html lang="en">
<head>
    <style>
        #navigator {
            position: absolute;
            ackground-color: red;
        }

        .current_bg {
            background-color: green !important;
        }
    </style>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<div id="navigator" class="current_bg"> 显示为绿色</div>
</body>
</html>

此时无需作任何其他改动即可生效。可见第二种方案更简单一些。

【论文复现】一种基于价格弹性矩阵的居民峰谷分时电价激励策略【需求响应】(Matlab代码实现)内容概要:本文介绍了一种基于价格弹性矩阵的居民峰谷分时电价激励策略,旨在通过需求响应机制优化电力系统的负荷分布。该研究利用Matlab进行代码实现,构建了居民用电行为与电价变动之间的价格弹性模型,通过分析不同时间段电价调整对用户用电习惯的影响,设计合理的峰谷电价方案,引导用户错峰用电,从而实现电网负荷的削峰填谷,提升电力系统运行效率与稳定性。文中详细阐述了价格弹性矩阵的构建方法、优化目标函数的设计以及求解算法的实现过程,并通过仿真验证了所提策略的有效性。; 适合人群:具备一定电力系统基础知识和Matlab编程能力,从事需求响应、电价机制研究或智能电网优化等相关领域的科研人员及研究生。; 使用场景及目标:①研究居民用电行为对电价变化的响应特性;②设计并仿真基于价格弹性矩阵的峰谷分时电价激励策略;③实现需求响应下的电力负荷优化调度;④为电力公司制定科学合理的电价政策提供理论支持和技术工具。; 阅读建议:建议读者结合提供的Matlab代码进行实践操作,深入理解价格弹性建模与优化求解过程,同时可参考文中方法拓展至其他需求响应场景,如工业用户、商业楼宇等,进一步提升研究的广度与深度。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值