css 權重值(層疊性)詳解

  • 2019 年 10 月 8 日
  • 筆記

目錄

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'>GGG</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>猜猜我是什麼顏色</span>          </div>      </body>  </html>
  • 執行結果
  • 小結: 使用!important是一個壞習慣,應該盡量避免,因為這嚴重破壞了樣式表中固有的權重值比較規則,使得在調試bug變得更加困難。當兩條相互衝突的帶有!important規則作用與同一個標籤,那麼擁有最大優先級的將會被採用。

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

  • 第一種
    • 你的網站上有一個設計了全站樣式的css文件
    • 同時你或者你的小夥伴寫了一些很差的內聯樣式
  • 第二種 box p { color: blue; } p.awesome { color: red; } 怎樣才能使得文本的顏色變為紅色?這種情況下,如果不適用!important.第一條規則永遠大於第二條的規則。

總結

歡迎評論點贊交流,轉發請添加原博客連接謝謝!

作 者:郭楷豐