整合營銷服務商

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

          免費咨詢熱線:

          CSS變量 var()的用法是什么?CSS變量 var()的用法詳解

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

          么是HTML / HTM文件?他們相差一個字母有什么區別嗎,如何查看或編輯源代碼以及如何轉換成其他格式,例如DOCX,PDF,JPG 等,針對這些問題編程獅W3Cschool整理以下資料希望能對你有所幫助:

          什么是HTM或HTML文件?

          HTM / HTML 文件是超文本標記語言(Hyper Text Markup Language)文件,是 Internet 上的標準網頁文件類型。

          由于 HTM 文件是純文本文件,因此它們僅包含文本(例如您現在正在閱讀的內容)以及對其他外部文件的文本引用(例如本文中的配圖)。

          HTM 和 HTML 文件還可以引用其他文件,例如視頻,CSS 或 JS 文件。

          HTM與HTML的區別

          HTM 與 HTML 沒有本質意義的區別,只是為了滿足 DOS 僅能識別 8+3 的文件名而已,因為一些老的系統 (win32) 不能識別四位文件名,所以某些網頁服務器要求 index.html 最后一個 l 不能省略。MSIE 能自動識別和打開這些文件,但編寫網頁地址的時候必須是完全對應的,也就是說 index.htmindex.html 是兩個不同的文件,對應著不同的地址。值得一提的是 UNIX 系統中對大小寫敏感,不吻合的話就可能報沒有文件或者找不到文件。

          如何打開HTM或HTML文件?

          任何 Web 瀏覽器,例如 Edge,Firefox,Chrome,Opera,IE,360 安全瀏覽器等,都可以打開并正確顯示 HTM 和 HTML 文件。換句話說,在瀏覽器中打開這些文件并“解碼(decode)” HTM 或 HTML 文件使其能正確顯示。

          現在有很多簡化編輯和創建 HTM / HTML 文件的工具。一些著名的免費 HTML 編輯器包括 Eclipse ,Komodo Edit 和 Bluefish 。另一個流行的具有許多高級功能的 HTM / HTML 編輯器是 Adobe Dreamweaver ,不過它是收費的。

          雖然 Windows 系統自帶的記事本等簡單的文本編輯器的功能不如專用的 HTM 編輯器那么豐富,但是對 HTM 或 HTML 文件進行簡單編輯修改還是可以的。不過,W3Cschool還是建議大家使用專用的編輯器,如 WebStorm、VS Code 等,它具更多專業功能。

          這是一個非常簡單的 HTML 頁面以文本形式顯示的示例:

          源碼:

          <!doctype html>
          <html>
          
              
          <head>
          <meta charset="utf-8">
          <title>什么是HTM或HTML文件? - 編程獅(w3cschool.cn)</title>
          </head>
          
          
          <body>
              <h1>什么是HTM或HTML文件?</h1>
              <p>HTM / HTML 文件是超文本標記語言(Hyper Text Markup Language)文件,是 Internet 上的標準網頁文件類型。</p>
              <p>由于 HTM 文件是純文本文件,因此它們僅包含文本(例如您現在正在閱讀的內容)以及對其他外部文件的文本*引用*(例如本文中的配圖)。</p>
              <p>HTM 和 HTML 文件還可以引用其他文件,例如視頻,CSS 或 JS 文件。</p>   
          </body>
          
              
          </html>

          當 Web 瀏覽器呈現信息時,HTML 文件的源代碼被“轉換”為真實的網頁(盡管源代碼已很精簡了)。

          如何轉換HTML和HTM文件?

          HTM 文件以特定的語法(規則)構成,以使其中的代碼和文本在瀏覽器中打開時能夠正確顯示。因此,將 HTM / HTML 文件轉換為另一種格式可能會丟失頁面上的所有功能。

          如果你想要做的是將一個 HTM / HTML 文件轉換為方便離線查看的文件,這時圖片或 PDF 格式會方便很多。

          在 Chrome 中,鼠標右鍵單擊網頁,出現的選項菜單中進入 “打印(P)...”(快捷鍵:CTRL + P) ,在打印選項中選擇另存為 PDF,以將窗口中的頁面轉換為 PDF 文件。Chrome 瀏覽器的擴展功能也稱為“全屏截屏”,可將 Chrome 瀏覽器中所有打開的 HTM / HTML 文件轉換為 PNG 文件。

          其他瀏覽器具有類似的功能,例如 Firefox 的 “另存為 PDF” 加載項。

          您也可以使用專門用于 HTM / HTML 進行圖像文件轉換的網站,例如iWeb2Shot 或Web-capture 。

          一個免費的文件轉換器可以用來轉換并保存 HTM / HTML 文件到您的計算機。如 FileZigZag 是一個免費的文檔轉換器網站,可將 HTM 轉換為RTF,EPS,CSV,PDF 和許多其他格式。

          HTM / HTML 文件不能轉換為文本文件格式以外的任何格式。例如,HTML 文件永遠不能轉換為 MP3 音頻文件。

          文件打不開?

          HTML / HTM 文件應該很容易打開,因為它們只是任何 Web 瀏覽器都可以查看的文本文件。如果您的文件沒有從上面建議的任何程序打開,則很有可能正在打開的這個文件并非超文本標記語言文件。

          某些文件格式使用的文件擴展名與 HTML / HTM 非常相似,但實際上并非相同。一個主要的示例是用于壓縮 HTML 電子書文件的 HTMLZ 文件擴展名。有 HTML 文件在內的 HTMLZ 文件,但整個包的格式為 ZIP,不會在 Web 瀏覽器或文本編輯器打開。

          在此示例中,您需要特定的 HTMLZ 文件查看器,例如Caliber 。或者,由于此文件格式實際上是存檔,因此您可以使用 7-Zip 之類的文件解壓縮器將其打開,然后您可以使用網絡瀏覽器或上述任何其他 HTML 查看器/編輯器打開任何單獨的 HTML 文件。

          TMLANGUAGE 是另一個可能與 HTML / HTM 文件混淆的文件擴展名。這些實際上是TextMate 用于 macOS 的 TextMate 語言語法文件。

          以上就是編程獅W3Cschool為你整理的關于《什么是HTM或HTML文件?如何打開、編輯和轉換HTM和HTML文件?》的全部內容,現希望可以幫到你~

          則表達式(英語:Regular Expression,在代碼中常簡寫為regex、regexp或RE)使用單個字符串來描述、匹配一系列符合某個句法規則的字符串搜索模式。

          搜索模式可用于文本搜索和文本替換。


          什么是正則表達式?

          正則表達式是由一個字符序列形成的搜索模式。

          當你在文本中搜索數據時,你可以用搜索模式來描述你要查詢的內容。

          正則表達式可以是一個簡單的字符,或一個更復雜的模式。

          正則表達式可用于所有文本搜索和文本替換的操作。

          語法

          /正則表達式主體/修飾符(可選)

          其中修飾符是可選的。

          實例:

          var patt = /runoob/i

          實例解析:

          /runoob/i 是一個正則表達式。

          runoob 是一個正則表達式主體 (用于檢索)。

          i 是一個修飾符 (搜索不區分大小寫)。


          使用字符串方法

          在 JavaScript 中,正則表達式通常用于兩個字符串方法 : search() 和 replace()。

          search() 方法 用于檢索字符串中指定的子字符串,或檢索與正則表達式相匹配的子字符串,并返回子串的起始位置。

          replace() 方法 用于在字符串中用一些字符替換另一些字符,或替換一個與正則表達式匹配的子串。


          search() 方法使用正則表達式

          實例

          使用正則表達式搜索 "Runoob" 字符串,且不區分大小寫:

          varstr = "Visit Runoob!"; varn = str.search(/Runoob/i);

          輸出結果為:

          6


          search() 方法使用字符串

          search 方法可使用字符串作為參數。字符串參數會轉換為正則表達式:

          實例

          檢索字符串中 "Runoob" 的子串:

          varstr = "Visit Runoob!"; varn = str.search("Runoob");


          replace() 方法使用正則表達式

          實例

          使用正則表達式且不區分大小寫將字符串中的 Microsoft 替換為 Runoob :

          varstr = document.getElementById("demo").innerHTML; vartxt = str.replace(/microsoft/i,"Runoob");

          結果輸出為:

          Visit Runoob!

          replace() 方法使用字符串

          replace() 方法將接收字符串作為參數:

          varstr = document.getElementById("demo").innerHTML; vartxt = str.replace("Microsoft","Runoob");


          正則表達式修飾符

          修飾符 可以在全局搜索中不區分大小寫:

          正則表達式參數可用在以上方法中 (替代字符串參數)。

          正則表達式使得搜索功能更加強大(如實例中不區分大小寫)。

          修飾符描述
          i執行對大小寫不敏感的匹配。
          g執行全局匹配(查找所有匹配而非在找到第一個匹配后停止)。
          m執行多行匹配。

          正則表達式模式

          方括號用于查找某個范圍內的字符:

          表達式描述
          [abc]查找方括號之間的任何字符。
          [0-9]查找任何從 0 至 9 的數字。
          (x|y)查找任何以 | 分隔的選項。

          元字符是擁有特殊含義的字符:

          元字符描述
          \d查找數字。
          \s查找空白字符。
          \b匹配單詞邊界。
          \uxxxx查找以十六進制數 xxxx 規定的 Unicode 字符。

          量詞:

          量詞描述
          n+匹配任何包含至少一個 n 的字符串。
          n*匹配任何包含零個或多個 n 的字符串。
          n?匹配任何包含零個或一個 n 的字符串。

          使用 RegExp 對象

          在 JavaScript 中,RegExp 對象是一個預定義了屬性和方法的正則表達式對象。


          使用 test()

          test() 方法是一個正則表達式方法。

          test() 方法用于檢測一個字符串是否匹配某個模式,如果字符串中含有匹配的文本,則返回 true,否則返回 false。

          以下實例用于搜索字符串中的字符 "e":

          實例

          var patt = /e/;

          patt.test("The best things in life are free!");

          字符串中含有 "e",所以該實例輸出為:

          true

          你可以不用設置正則表達式的變量,以上兩行代碼可以合并為一行:

          /e/.test("The best things in life are free!")


          使用 exec()

          e


          主站蜘蛛池模板: 少妇精品久久久一区二区三区| 日韩一区二区三区无码影院| 一区国严二区亚洲三区| 国产精品无码一区二区三区不卡 | 免费人妻精品一区二区三区| 国产免费一区二区三区不卡| 日本v片免费一区二区三区| 国产亚洲一区二区手机在线观看| 精品国产伦一区二区三区在线观看| 一区二区3区免费视频| 国产精品成人一区二区三区| 无码国产精品久久一区免费 | 亚洲av无码片区一区二区三区| 亚洲一区无码精品色| 精品国产AV无码一区二区三区| 亚洲视频一区二区三区| 无码毛片视频一区二区本码| 中文字幕一区视频一线| 亚洲国产精品一区二区九九 | 无码少妇一区二区| 国产AV国片精品一区二区| 精品一区二区三区在线观看l| 肉色超薄丝袜脚交一区二区| 久久国产一区二区| 亚洲一区二区影视| 中文字幕乱码亚洲精品一区| 久久久精品人妻一区亚美研究所| 区三区激情福利综合中文字幕在线一区亚洲视频1 | 人妻天天爽夜夜爽一区二区| 亚洲AV无码一区二三区| 日本美女一区二区三区| 精品日韩一区二区| 欧洲精品码一区二区三区免费看| 无码精品蜜桃一区二区三区WW| 亚洲av区一区二区三| 国精品无码一区二区三区在线蜜臀| 免费观看一区二区三区| 亚洲AV午夜福利精品一区二区| 日韩人妻无码一区二区三区99 | 亚洲日本一区二区三区在线| 一区二区乱子伦在线播放|