初次接觸CSS變量

本文的目的主要是展現CSS變量是如何工做的。隨着Web應用程序變得愈來愈大,CSS變得愈來愈大,愈來愈多,並且不少時候都很亂,在良好的上下文中使用CSS變量,爲您提供重用和輕鬆更改重複出現的CSS屬性的機制。javascript

在「純粹的」CSS支持變量以前,咱們有像LessSass這樣的預處理器可是它們須要在使用前進行編譯,所以(有時)會增長額外的複雜性。css

 

如何定義和使用CSS變量

從咱們最熟悉的語言JavaScript開始:在JavaScript中定義變量使用vars。html

要聲明一個簡單的JavaScript var,以下內容:java

var mainColor = 'red';

 

要聲明一個CSS變量,您必須在該var的名稱前添加一個雙短劃線。例如:web

body{
    --color:red;
}

 

如今,爲了使用CSS變量的值,咱們可使用var(...)函數。以下:瀏覽器

.demo{
    background:var(--color);
}

 

管理CSS變量的最簡單方法是將它們聲明爲:root僞類。鑑於CSS變量遵循規則,就像任何其餘CSS定義同樣,將它們放在:root中將確保全部選擇器均可以訪問這些變量。sass

:root{
    --color:red;
}
            
.demo{
    background:var(--color);
}
            
p{
    color:var(--color);
}

瀏覽器支持CSS變量?

瀏覽器對CSS變量的支持還算不錯的。只是IE瀏覽器不支持。想查看瀏覽器兼容性的能夠點擊這裏那麼您將看到全部主流瀏覽器都支持開箱即用的CSS變量。不管是手機仍是臺式機。less

 

CSS變量的實質應用

示例1 - 管理顏色

到目前爲止,使用CSS變量的最佳候選者之一是管理網頁的顏色。咱們能夠將它們放在變量中,而不是一遍又一遍地複製和粘貼相同的顏色。若是有人要求咱們更新特定的綠色陰影或使全部按鈕變爲紅色而不是藍色,那麼只需更改該CSS變量的值,就是這樣。您沒必要搜索和替換該顏色的全部實例。ide

列如:函數

CSS代碼

/*css_vars.css*/
:root {
  --primary-color: #ed6564;
  --accent-color: #388287;
}

html {
  background-color: var(--primary-color);
}

h3 {
  border-bottom: 2px solid var(--primary-color);
}

button {
  color: var(--accent-color);
  border: 1px solid var(--accent-color);
}

p {
  color: var(--accent-color);
}


/*base.css*/
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  padding: 30px;
  font: normal 13px/1.5 sans-serif;
  color: #546567;
  background-color: var(--primary-color);
}

.container {
  background: #fff;
  padding: 20px;
}

h3 {
  padding-bottom: 10px;
  margin-bottom: 15px;
}

p {
  background-color: #fff;
  margin: 15px 0;
}

button {
  margin:0 5px;
  font-size: 13px;
  padding: 8px 12px;
  background-color: #fff;
  border-radius: 3px;
  box-shadow: none;
  text-transform: uppercase;
  font-weight: bold;
  cursor: pointer;
  opacity: 0.8;
  outline: 0;
}

button:hover {
  opacity: 1;
}

.center {
  text-align: center;
}

 

HTML代碼

<div class="container">
  <h3>就業協議書</h3>
  <p>就業協議書,全稱是《全國普通高等學校畢業生就業協議書》,是由教育部高校學生司統一制訂的。根據國家規定,在達成就業意向後,畢業生、用人單位、學校三方必須簽定《全國普通高等學校畢業生就業協議書》。就業協議書是具備必定的普遍性和權威性,是學校制訂就業方案派遣畢業生、用人單位申請用人指標的主要依據,對簽約的三方都有約束力。</p>
  <div class="center">
    <button>查看詳情</button><button>取消</button>
  </div>
</div>

點擊查看運行結果。

 

示例2 - 刪除重複的代碼

一般,您須要構建一些不一樣的組件變體。相同的基本樣式,略有不一樣。讓咱們使用一些顏色不一樣的按鈕。典型的解決方案是建立一個基類,好比.btn並添加變體類。

.btn {
  border: 2px solid black;}

.btn:hover {
  background: black;}

.btn.red {
  border-color: red
}
.btn.red:hover {
  background: red
}

 

如今使用它們像這樣:

<button class="btn">Hello</button>
<button class="btn red">Hello</button>

可是,這會添加一些代碼重複。在.red變體上,咱們必須將border-color和background設置爲紅色。

 

這中狀況可使用CSS變量輕鬆修復。以下:

CSS代碼:

.btn{
  border-radius:4px;
  text-align:center;
  padding:.5em;
  margin-bottom:0.5em;
  background:#fff;
  border:1px solid var(--color, black);
}

.btn:hover{
  color:#fff;
  cursor:pointer;
  background:var(--color, black);
}

.btn.red{
  --color:red;
}

.btn.green{
  --color:green;
}

.btn.blue{
  --color:blue;
}

 

HTML代碼:

<div class="btn">HMOE</div>
<div class="btn red">HMOE</div>
<div class="btn green">HMOE</div>
<div class="btn blue">HMOE</div>

 

示例3 - 使一些屬性可讀

若是咱們想要建立更復雜的屬性值的快捷方式,CSS vars很是適合使用,所以咱們沒必要記住它。CSS屬性,如box-shadow,transform和font或其餘帶有多個參數的CSS規則就是完美的例子。咱們能夠將屬性放在變量中,以便咱們能夠經過更易讀的格式重用它。

例如:

:root {
  --tiny-shadow: 4px 4px 2px 0 rgba(0, 0, 0, 0.8);
  --animate-right: translateX(20px);
}

li {
  box-shadow: var(--tiny-shadow);
}

li:hover {
  transform: var(--animate-right);
}

 

例4 - 級聯變量

標準級聯規則也適用於CSS變量。所以,若是屢次聲明自定義屬性,則css文件中最低的定義將覆蓋其上方的定義。下面的示例演示了動態操做用戶操做的屬性是多麼容易,同時仍然保持代碼清晰簡潔。

CSS_var.css文件:

.orange-container {
  --main-text: 18px;
}

.orange-container:hover { --main-text: 22px; }

.red-container:hover { --main-text: 26px; }

.title { font-size: var(--title-text); }

.content { font-size: var(--main-text); } .container:hover { --main-text: 18px; }

 

base.css文件:

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  background: #eee;
  padding: 30px;
  font: 500 14px sans-serif;
  color: #333;
  line-height: 1.5;
}

.orange-container {
  background: orange;
}

.red-container {
  background: red;
}

.red-container,
.orange-container {
  padding-top: 10px;
  padding-left: 50px;
}

.container {
  background: blue;
  padding: 20px;
  color: white;
}

p {
  transition: 0.4s;
}

.title {
  font-weight: bold;
}

 

index.html文件:

<html>

<head>
<link rel="stylesheet" type="text/css" href="base.css">
<link rel="stylesheet" type="text/css" href="css_vars.css">
</head>

<body>
<div class="orange-container">
    Hover orange to make blue bigger.
    <div class="red-container">
         Hover red to make blue even bigger.
        <div class="container">
            <p class="content">Hover on the different color areas to change the size of this text and the title.</p>
        </div>
    </div>
</div>
</body>

</html>

點擊查看運行結果。

 

示例5 - 具備CSS變量的主題切換器

CSS變量的一個好處是它的反應性。一旦咱們更新它,任何具備CSS變量值的屬性也會更新。所以,只需幾行Javascript和CSS變量的智能使用,咱們就能夠製做一個主題切換器機制。

例如:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>具備CSS變量的主題切換器</title>    
        <style>
            
            body {
              background-color: var(--bg, #b3e5fc);
              color: var(--bg-text, #37474f);
              font-family: sans-serif;
              line-height: 1.3;
            }
            
            .toolbar {
              text-align: center;
            }
            
        </style>
    </head>
    <body>
        
        <div class="toolbar">
            <button value="dark">dark</button>
            <button value="calm">calm</button>
            <button value="light">light</button>
        </div>
    
        <h2>Stackoverflow Question</h2>
        <p>I would like to use an external javascript file in another javascript file. For example, I could store all my global variables
        in a globals.js file and then call then from the website logic logic.js. Then in the index.html, i would insert the tag.
        How do I use the globals.js inside the logic.js?
        </p>
        <script>
            var root = document.documentElement;
            var themeBtns = document.querySelectorAll(".toolbar > button");
            
            themeBtns.forEach(function (btn){
              btn.addEventListener("click", handleThemeUpdate);
            });
            
            function handleThemeUpdate(e) {
              switch (e.target.value) {
                case "dark":
                  root.style.setProperty("--bg", "black");
                  root.style.setProperty("--bg-text", "white");
                  break;
                case "calm":
                  root.style.setProperty("--bg", "#B3E5FC");
                  root.style.setProperty("--bg-text", "#37474F");
                  break;
                case "light":
                  root.style.setProperty("--bg", "white");
                  root.style.setProperty("--bg-text", "black");
                  break;
              }
            }
        </script>

    </body>
</html>

點擊查看運行結果

 

 

CSS變量的使用提示

像CSS中幾乎全部的東西同樣,變量也很是簡單易用。如下是一些未包含在示例中的提示,但在某些狀況下仍然很是有用:

1)css變量區分大小寫。下面的示例是兩個不一樣的變量:

:root {
   --color: blue;
   --COLOR: red;
}

2)當您使用var()函數時,您可使用第二個參數。若是找不到自定義屬性,將使用第二個參數爲默認值:

width: var(--custom-width, 50%);

3)能夠直接將CSS變量用於HTML:

<!--HTML-->
<html style="--size: 600px">

<!--CSS-->
body {
  max-width: var(--size)
}

4) 能夠在其餘CSS var中使用CSS變量:

--base-red-color: #f00;
--background-gradient: linear-gradient(to top, var(--base-red-color), #222);

5) 可使用媒體查詢使CSS變量成爲條件。例如,如下代碼根據屏幕大小更改填充的值:

:root {
    --padding: 15px 
}

@media screen and (min-width: 750px) {
    --padding: 30px
}

6) 不要懼怕在 clac() 函數中使用CSS變量

--text-input-width: 5000px;
max-width: calc(var(--text-input-width) / 2);

固然,CSS變量不是靈丹妙藥。不會解決你在CSS領域遇到的每個問題。可是,使用它使您的代碼更具可讀性和可維護性。此外,它極大地改善了大型文檔的易變性。只需將全部常量設置在一個單獨的文件中,當您只想對變量進行更改時,就沒必要跳過數千行代碼。

相關文章
相關標籤/搜索