css 權重值(層疊性)實例詳解

  發布時間:2019-06-11 14:46:27   作者:佚名   我要評論

這篇文章主要介紹了css 權重值(層疊性)實例詳解 ,需要的朋友可以參考下

•css中有很多選擇器,那在多個選擇器都作用于同一個元素的情況下會出現什么效果呢? 代碼

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <title></title>
    <style type="text/css">
      p{
        color:red;
        font-size: 10px;
      }
      #wrap{
        color: deeppink;
        font-size: 30px;
      }
      .box{
        color:yellow;
        font-size: 50px;
      }
    </style>
  </head>
  <body>
    <p class='box' id="wrap">
       猜猜我是什么顏色
    </p>
  </body>
</html>

•執行可結果

•小結 : 出現這種效果是因為瀏覽器是根據權重值來判斷使用哪種css樣式的,權重值高的它的優先級會越高,就會呈現那種css樣式,id選擇器的權重值為100>類選擇器10>標簽選擇器1,所以最終結果為id選擇器設置的樣式

•示列二 代碼

!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <title></title>
    <style type="text/css">
      *{
          color: cyan;
      }
      div {
          color: yellow;
      }
    </style>
  </head>
  <body>
    <div>
        <p class='box' id="wrap">
        猜猜我是什么顏色
        </p>
    </div>
  </body>
</html>

•執行結果

•小結 : 繼承元素是沒有權重值的,所以最終結果為通用選擇器設置的樣式

•實例三 代碼

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <title></title>
    <style type="text/css">
      p{
          color: yellow;
      }
      *{
          color: cyan;
      }
    </style>
  </head>
  <body>
    <div>
        <p class='box' id="wrap">
        猜猜我是什么顏色
        </p>
    </div>
  </body>
</html>

•執行結果

•小結 : 標簽選擇器的權重值是1,但是仍然大于通用選擇器,所以最終結果為標簽選擇器設置的樣式

•實例四 代碼

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <title></title>
    <style type="text/css">
      div p{
          color: yellow;
      }
      div>p{
          color: cyan;
      }
      p{
          color: red;
      }
    </style>
  </head>
  <body>
    <div>
        <p class='box' id="wrap">
        猜猜我是什么顏色
        </p>
    </div>
  </body>
</html>

•執行結果

•實例五 代碼

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <title></title>
    <style type="text/css">
      div>p{
          color: cyan;
      }
      div p{
          color: yellow;
      }
      p{
          color: red;
      }
    </style>
  </head>
  <body>
    <div>
        <p class='box' id="wrap">
        猜猜我是什么顏色
        </p>
    </div>
  </body>
</html>

•執行結果

權重值的計算

<!--有一個這樣的結構:-->
<div class='wrap1' id='box1'>
    <div class="wrap2" id="box2">
        <p class='active'>MJJ</p>
    </div>
</div>

<!--舉幾個例子看看他們的權重值:-->
p{color:gray;}                          <!--權值為1-->
div div p{color:yellow;}                  <!--權值為1+1+1=3-->
.active{color:red;}                       <!--權值10-->
div .active{color:black;}                <!--權值為11-->
div div .active{color:blue;}             <!--權值為12-->
.wrap #box2 .active{color:purple;}        <!--權值為120-->
#box1 #box2 .active{color:green;}        <!--權值為210-->

<!--由此可以看出,其實對于權重值的計算來說,首先它是不進位的,對于使用的選擇器我們無非就是在數數,數選擇器的數量(按照順序來,先是id再是class,再是元素),比如:-->
#box1 .wrap2 div{ color:red; } <!--權值為 1  1  1-->

注意:繼承來的屬性也有權重值,不過它的權值非常低,可以理解為繼承的權重值最低。

!important 提升權重值實例
<!--我們在做網頁代碼時,有些特殊的情況需要為某些樣式設置具有最高權重值,怎么辦?比如我們知道內聯樣式的權重值是1000,比較大,那么我們可以使用!important來解決。-->   
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>!important的使用</title>
        <style type="text/css">
            div{
                color:green !important;
            }
        </style>
    </head>
    <body>
        <div id="box" style="color:red;">
            <span>MJJ</span>
        </div>
    </body>
</html>

•執行結果

•小結: 使用!important是一個壞習慣,應該盡量避免,因為這嚴重破壞了樣式表中固有的權重值比較規則,使得在調試bug變得更加困難。當兩條相互沖突的帶有!important規則作用與同一個標簽,那么擁有最大優先級的將會被采用。

什么情況下可以使用!important ?

•第一種

◦你的網站上有一個設計了全站樣式的css文件
◦同時你或者你的小伙伴寫了一些很差的內聯樣式

•第二種

box p { color: blue; } p.awesome { color: red; }

怎樣才能使得文本的顏色變為紅色?這種情況下,如果不適用!important.第一條規則永遠大于第二條的規則。

總結:

總結

以上所述是小編給大家介紹的css 權重值(層疊性)實例詳解 ,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

相關文章

  • CSS中選擇器的權重值的計算

    這篇文章主要介紹了CSS中選擇器的權重值的計算的相關資料,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-23
  • 淺談CSS中的繼承性,特殊性,層疊性和重要性

    下面小編就為大家帶來一篇淺談CSS中的繼承性,特殊性,層疊性和重要性。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-08-09

最新評論

湖北11选5走势图爱彩乐