zoukankan      html  css  js  c++  java
  • css中的权重问题

    css中的权重问题

    问题

    是否css的加载顺序就一定是:行内 > 内部 > 外部 / id选择器 > class选择器???

    本章主要分析css中的权重问题。在我们学习时,经常听说:样式有三种书写方式,第一种是行内样式,第一种是内部样式,最后一种是外部样式。在我们引入样式的时候,毫无疑问行内样式优先级是最高的,内部样式理所当然会覆盖外部样式。id选择器也会大于class选择器。当时没有多深究,就信了,在以后一段时间里,就使用这种规则去写代码,是ok的。直到有一次看书时联想到了这个问题,就开始重新测试……

    首先,内部样式会覆盖外部样式。

    /*test.css*/
    #div { color: red; }
    
    
    <link rel="stylesheet" href="test.css">
    <style>
      #div {
        color: yellow;
      }
    </style>
    
    <div id='div'>
      <p id='p'>我是测试的</p>
    </div>
    
    

    然后,id选择器 > class选择器

    <style>
      #div { color: yellow; }
      .div { color: red; }
    </style>
    
    <div id='div' class='div'>
      <p id='p'>我是测试的</p>
    </div>
    
    

    问题即将来临

    /*test.css*/
    #div { color: red; }
    
    
    <style>
      #div {
        color: yellow;
      }
    </style>
    <link rel="stylesheet" href="test.css">    <!-- 在后边引入 -->
    
    <div id="div">
      <p id="p">我是测试的</p>
    </div>
    
    

    不是说好的内部优先级高于外部?按照加载的顺序,后加载的就覆盖之前的,这还可以接受。

    但是

    <style>
      #div p { color: red; }
      #p { color: yellow; }
    </style>
    
    <div id="div" class="div">
      <p id="p">这里是测试文本</p>
    </div>
    
    

    不是说id选择器优先级应该要高于class和tag标签选择器,所以#p的优先级是最高的才是……由此进入主要内容——css权重

    概述

    css最终显示的样式是由权重决定的,每种选择器都有一个权重值,不管谁先加载或后加载,谁的权重值最大,就显示谁,如果相同,则显示后声明。从0开始,行内样式+1000,id+100,属性选择器/class或者伪类(包括结构伪类选择器)+10,元素名或者伪元素+1。并且做加法时不进位。例如:

    #div .test p {}  /* 0111 */
    body#container div {}   /* 0102 */
    /*相加不进位*/
    .p1 .p2 .p3 .p4 .p5 .p6 .p7 .p8 .p9 .p10 .p11 div { color: red; }    /* 0,0,11,1 */
    #p1 div { color: yellow; }    /* 0,1,0,1 */  /* 大于上边一行的权重,所以显示黄色的 */
    
    
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
        <style>
            .p1 .p2 .p3 .p4 .p5 .p6 .p7 .p8 .p9 .p10 .p11 span { color: red; }
            #div span { 
                color: yellow; 
    		}
        </style>
    </head>
    <body>
        <div id="div">
            <p class="p1">
                <p class="p2">
                    <p class="p3">
                        <p class="p4">
                            <p class="p5">
                                <p class="p6">
                                    <p class="p7">
                                        <p class="p8">
                                            <p class="p9">
                                                <p class="p10">
                                                    <p class="p11">
                                                        <span>我是测试的</span>
                                                    </p>
                                                </p>
                                            </p>
                                        </p>
                                    </p>
                                </p>
                            </p>
                        </p>
                    </p>
                </p>
            </p>
        </div>
    </body>
    </html>
    
    

    但是,又是一个新问题。

    <!DOCTYPE html>
    <html>
    <head>
    	<title></title>
    	<style type="text/css">
    		.a::after {
    			content: "哈哈哈";
    			color: #008000;
    		}
    		#al .a {
    			color: red;
    		}
    		span {
    			color: #00FFFF;
    		}
    	</style>
    </head>
    <body>
    	<div id="al">
    		<div class="a"> 
    			<!-- 在这里span继承了父级的样式,权重为0,但是它使用标签选择器设置了自身样式,权重为1,故,颜色不一样,上面的伪元素选择器也是。-->
    			<span class="b">哈哈哈哈</span>
    			啊啊啊
    		</div>
    	</div>
    </body>
    </html>
    

    这个就涉及另一个知识点,子元素从父元素继承而来的css样式权重为0。

    总结

    • 将权重想象成一个4位数(0000),初始都为0
    • 行内样式为(1000)
    • id选择器(0100)
    • 类选择器、伪类选择器、属性选择器、结构为类选择器(0010)
    • 标签选择器、伪元素选择器(0001)
    • !important权重最高
    • 从左往右比较,相等则继续,不等则停止,大的权重大
    • 从父级元素继承的选择器的权重为0。
  • 相关阅读:
    三步堵死SQL注入漏洞
    现在与大家探讨安全
    如何在SQL注入时保护数据库
    SQL注入与ASP木马上传
    C# 检查字符串,防SQL注入攻击
    关于对SQL注入80004005 及其它错误消息分析
    SQL注入入侵动网SQL版论坛
    天晨设计整站SQL注入漏洞
    用vbs来写sql注入等80端口的攻击脚本
    利用SQL注入2分钟入侵网站全程实录
  • 原文地址:https://www.cnblogs.com/JonnyJiang-zh/p/13566117.html
Copyright © 2011-2022 走看看