整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          什么是 CSS 變量,如何使用它們?

          SS 變量(正式術語稱為 CSS 自定義屬性),其行為與其他編程語言中的變量非常相似。可以用來將 CSS 文檔中那些重復的特定值命名為變量。CSS 變量以兩個破折號(--)為前綴(例如--my-color: black)來定義變量。

          要訪問變量,您可以使用該var()函數(例如color: var(--my-color))。CSS 變量對于在不同元素和組件之間共享樣式非常有用。

          最常見的用例之一是制作網站主題。CSS 變量在整個網站上創建公共的主題,并輕松將其換成不同的主題。這通常是將一個類應用于一個共同的祖先元素(例如<body>元素)來實現的。此示例演示了:root根元素中定義的全局變量,然后再body元素從其父級繼承值:

          /* 在根元素上定義公共的主題變量*/
          :root {
            --bg-color: #fff;
            --main-color: #000;
            --secondary-color: #222;
          }
          /*在body元素上使用這些變量 */
          body {
            background-color: var(--bg-color);
            color: var(--main-color);
          }
          small {
            color: var(--secondary-color);
          }
          /* 定義另一個暗黑主題,可以覆蓋默認主題*/
          body.dark {
            --bg-color: #080808;
            --main-color: #fff;
            --secondary-color: #ccc;
          }

          另一個示例,在制作組件時定義不同的樣式,比如下面按鈕組件:

          .btn {
            --bg-color: #002299;
            --text-color: #fff;
            --highlight-color: #669900;
          
            background-color: var(--bg-color);
            color: var(--text-color);
          }
          /* .btn 按鈕子元素使用 --highlight-color 顏色 */
          .btn .highlight {
            color: var(--highlight-color);
          }
          /* 定義警告按鈕的樣式, 覆蓋默認變量 */
          .btn-danger {
            --bg-color: #dd4a68;
            --text-color: #000;
            --highlight-color: #990055;
          }

          最后,請記住在使用 CSS 變量時要注意事項:

          • 您可以通過向var()函數提供第二個參數來定義備用值(例如var(--text-color, black),如果--text-color未定義時,默認為black)。
          • CSS 變量區分大小寫,因此請注意大小寫。它們也可以在 HTML 內聯樣式中使用(例如<div style="--text-color: red">)。
          • 您可以嵌套var()調用,使用另一個變量作為備用值(例如var(--main-color, var(--other-color)))。
          • 也可以將它們傳遞給其他函數,例如calc()函數(例如calc(--width - 10px))。
          • 甚至將一個變量分配給另一個變量(例如--text-color: var(--main-color))。

          文的目的主要是展示CSS變量是如何工作的。隨著Web應用程序變得越來越大,CSS變得越來越大,越來越多,而且很多時候都很亂,在良好的上下文中使用CSS變量,為您提供重用和輕松更改重復出現的CSS屬性的機制。

          在“純粹的”CSS支持變量之前,我們有像LessSass這樣的預處理器。但是它們需要在使用前進行編譯,因此(有時)會增加額外的復雜性。

          如何定義和使用CSS變量

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

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

          var mainColor = 'red';

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

          body{ --color:red; }

          現在,為了使用CSS變量的值,我們可以使用var(...)函數。如下:

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

          管理CSS變量的最簡單方法是將它們聲明為:root偽類。鑒于CSS變量遵循規則,就像任何其他CSS定義一樣,將它們放在:root中將確保所有選擇器都可以訪問這些變量。

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

          瀏覽器支持CSS變量?

          瀏覽器對CSS變量的支持還算不錯的。只是IE瀏覽器不支持。那么您將看到所有主流瀏覽器都支持開箱即用的CSS變量。無論是手機還是臺式機。

          CSS變量的實質應用

          示例1 - 管理顏色

          到目前為止,使用CSS變量的最佳候選者之一是管理網頁的顏色。我們可以將它們放在變量中,而不是一遍又一遍地復制和粘貼相同的顏色。如果有人要求我們更新特定的綠色陰影或使所有按鈕變為紅色而不是藍色,那么只需更改該CSS變量的值,就是這樣。您不必搜索和替換該顏色的所有實例。

          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領域遇到的每一個問題。但是,使用它使您的代碼更具可讀性和可維護性。此外,它極大地改善了大型文檔的易變性。只需將所有常量設置在一個單獨的文件中,當您只想對變量進行更改時,就不必跳過數千行代碼。

          什么需要變量呢?

          在所有的程序語言中,變量的設置都是最開始的學習內容,那為什么各種程序都需要變量呢?變量的最大的好處就是可以降低代碼的大小,通過在內容空間中存儲一個變量就可以在之后的程序中多次使用該變量,甚至可以通過簡單的計算得到多個值。在傳統的CSS中有些屬性值字符長度大,且需要重復設置,這樣就不可避免的增大了頁面的體積。還有有些響應式網站中應用到的比例布局,這時候需要根據父元素寬高屬性通過一個比例計算來設置新元素的寬高,這個工作費時且費力。所以市面上就出現了SASS和LESS等css的預編譯工具,就是為了給開發者提升一個開發效率。

          在這里我還是要推薦下我自己建的web前端開發學習群:731669587,群里都是學web前端開發的,如果你正在學習前端 ,小編歡迎你加入,今天分享的這個案例已經上傳到群文件,大家都是軟件開發黨,不定期分享干貨(只有前端軟件開發相關的),包括我自己整理的一份2018最新的前端進階資料和高級開發教程,歡迎進階中和進想深入前端的小伙伴。

          CSS原生變量

          ▼基本語法

          css的原生變量屬性基本按照以下語法來設置的:

          定義變量–變量名稱:變量值;,比如 –color:rgb(123,212,100);

          使用變量:var(–變量名),比如 background-color:var(–color)

          由上可得:

          CSS變量的權重跟CSS選擇器保持一致,如果變量所在的選擇器和使用變量的元素沒有交集,是沒有效果的。例如#alert定義的變量,只有id為alert的元素才能享有。如果你想變量全局使用,則你可以設置在:root選擇器上;

          當存在多個同樣名稱的變量時候,變量的覆蓋規則由CSS選擇器的權重決定的。


          主站蜘蛛池模板: 日本韩国一区二区三区| 亚洲高清一区二区三区 | 亚洲一区二区三区乱码在线欧洲| 国模极品一区二区三区| 亚洲不卡av不卡一区二区| 国产MD视频一区二区三区| 亚洲熟女www一区二区三区| 91精品福利一区二区三区野战| 国产精品毛片a∨一区二区三区 | 日韩精品无码一区二区视频| 国产一区二区三区无码免费| 无码丰满熟妇浪潮一区二区AV | 亚洲国产欧美国产综合一区| 亚洲乱码一区二区三区在线观看| 香蕉久久AⅤ一区二区三区| 国产日韩视频一区| 国产精品久久无码一区二区三区网 | 日韩一区二区三区在线观看| 精品国产一区在线观看| 亚洲av无码一区二区三区人妖| 麻豆一区二区在我观看| 国产成人精品视频一区二区不卡| 国产av天堂一区二区三区| 国产一区二区三区在线视頻| 岛国精品一区免费视频在线观看| 日韩一区二区在线观看| 国产免费伦精品一区二区三区| 日本精品一区二区三区四区| 国产一区二区精品久久岳√| 精品视频午夜一区二区| 一区二区三区精品视频| 中文无码AV一区二区三区 | 伊人久久精品一区二区三区| 日韩中文字幕精品免费一区| 亚洲综合av一区二区三区 | 无码人妻AV免费一区二区三区| 一区二区三区在线免费看| 亚洲一区免费在线观看| 成人精品一区二区三区校园激情| 成人精品一区久久久久| 大伊香蕉精品一区视频在线|