搜尋
首頁web前端css教學CSS中變數的用法介紹(附範例)

這篇文章帶給大家的內容是關於CSS中變數的用法介紹(附範例),有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。

前兩天看到阮大神的一篇在css中使用變數的文章,整理了一下。

這個重要的 CSS 新功能,所有主要瀏覽器已經都支援了。本文全面介紹如何使用它,你會發現原生 CSS 從此變得異常強大。

一、變數的宣告

宣告變數的時候,變數名稱前面要加上兩根連接詞線(--) 。

body {
  --foo: #7F583F;
  --bar: #F7EFD2;
}

上面程式碼中,body選擇器裡面宣告了兩個變數:--foo和--bar。

它們與color、font-size等正式屬性沒有什麼不同,只是沒有預設意義。所以 CSS 變數(CSS variable)又叫做"CSS 自訂屬性"(CSS custom properties)。因為變數與自訂的 CSS 屬性其實是一回事。

你可能會問,為什麼選擇兩根連接詞線(--)表示變數?因為$foo被 Sass 用掉了,@foo被 Less 用掉了。為了不產生衝突,官方的 CSS 變數就改用兩根連接詞線了。

各種值都可以放入 CSS 變數。

:root{
  --main-color: #4d4e53;
  --main-bg: rgb(255, 255, 255);
  --logo-border-color: rebeccapurple;

  --header-height: 68px;
  --content-padding: 10px 20px;

  --base-line-height: 1.428571429;
  --transition-duration: .35s;
  --external-link: "external link";
  --margin-top: calc(2vh + 20px);
}

變數名稱大小寫敏感,--header-color和--Header-Color是兩個不同變數。

二、var() 函數

var()函數用來讀取變數。

a {
  color: var(--foo);
  text-decoration-color: var(--bar);
}

var()函數也可以使用第二個參數,表示變數的預設值。如果該變數不存在,就會使用這個預設值。

color: var(--foo, #7F583F);

第二個參數不處理內部的逗號或空格,都視為參數的一部份。

var(--font-stack, "Roboto", "Helvetica");
var(--pad, 10px 15px 20px);

var()函數也可以用在變數的宣告。

:root {
  --primary-color: red;
  --logo-text: var(--primary-color);
}

注意,變數值只能當屬性值,不能當屬性名。

.foo {
  --side: margin-top;
  /* 无效 */
  var(--side): 20px;
}

上面程式碼中,變數--side用作屬性名,這是無效的。

三、變數值的型別

如果變數值是一個字串,可以與其他字串拼接。

--bar: 'hello';
--foo: var(--bar)' world';

利用這一點,可以 debug(範例)。

body:after {
  content: '--screen-category : 'var(--screen-category);
}

如果變數值是數值,不能與數值單位直接連用。

.foo {
  --gap: 20;
  /* 无效 */
  margin-top: var(--gap)px;
}

上面程式碼中,數值與單位直接寫在一起,這是無效的。必須使用calc()函數,將它們連接。

.foo {
  --gap: 20;
  margin-top: calc(var(--gap) * 1px);
}

如果變數值帶有單位,就不能寫成字串。

/* 无效 */
.foo {
  --foo: '20px';
  font-size: var(--foo);
}

/* 有效 */
.foo {
  --foo: 20px;
  font-size: var(--foo);
}

四、作用域

同一個 CSS 變量,可以在多個選擇器內宣告。讀取的時候,優先順序最高的聲明生效。這與 CSS 的"層疊"(cascade)規則是一致的。

下面是一個例子。

<style>
  :root { --color: blue; }
  p { --color: green; }
  #alert { --color: red; }
  * { color: var(--color); }</style><p>蓝色</p><p>绿色</p><p id="alert">红色</p>

上面程式碼中,三個選擇器都宣告了--color變數。不同元素讀取這個變數的時候,會採用優先順序最高的規則,因此三段文字的顏色是不一樣的。

這就是說,變數的作用域就是它所在的選擇器的有效範圍。

body {
  --foo: #7F583F;
}

.content {
  --bar: #F7EFD2;
}

上面程式碼中,變數--foo的作用域是body選擇器的生效範圍,--bar的作用域是.content選擇器的生效範圍。

由於這個原因,全域的變數通常放在根元素:root裡面,確保任何選擇器都可以讀取它們。

:root {
  --main-color: #06c;
}

五、響應式佈局

CSS 是動態的,頁面的任何變化,都會導致採用的規則變化。

利用這個特點,可以在響應式佈局的media指令裡面宣告變量,使得不同的螢幕寬度有不同的變數值。

body {
  --primary: #7F583F;
  --secondary: #F7EFD2;
}

a {
  color: var(--primary);
  text-decoration-color: var(--secondary);
}

@media screen and (min-width: 768px) {
  body {
    --primary:  #F7EFD2;
    --secondary: #7F583F;
  }
}

六、相容性處理

對於不支援 CSS 變數的瀏覽器,可以採用下面的寫法。

a {
  color: #7F583F;
  color: var(--primary);
}

也可以使用@support指令來偵測。

@supports ( (--a: 0)) {
  /* supported */
}
@supports ( not (--a: 0)) {
  /* not supported */
}

七、JavaScript 操作

JavaScript 也可以偵測瀏覽器是否支援 CSS 變數。

const isSupported =
  window.CSS &&
  window.CSS.supports &&
  window.CSS.supports(&#39;--a&#39;, 0);

if (isSupported) {
  /* supported */
} else {
  /* not supported */
}

JavaScript 操作 CSS 變數的寫法如下。

// 设置变量
document.body.style.setProperty(&#39;--primary&#39;, &#39;#7F583F&#39;);

// 读取变量
document.body.style.getPropertyValue(&#39;--primary&#39;).trim();
// &#39;#7F583F&#39;

// 删除变量
document.body.style.removeProperty(&#39;--primary&#39;);

這意味著,JavaScript 可以將任意值存入樣式表。下面是一個監聽事件的例子,事件資訊存入 CSS 變數。

const docStyle = document.documentElement.style;

document.addEventListener(&#39;mousemove&#39;, (e) => {
  docStyle.setProperty(&#39;--mouse-x&#39;, e.clientX);
  docStyle.setProperty(&#39;--mouse-y&#39;, e.clientY);
});

那些對 CSS 無用的信息,也可以放入 CSS 變數。

--foo: if(x > 5) this.width = 10;

上面程式碼中,--foo的值在 CSS 裡面是無效語句,但是可以被 JavaScript 讀取。這意味著,可以把樣式設定寫在 CSS 變數中,讓 JavaScript 讀取。

所以,CSS 變數提供了 JavaScript 與 CSS 通訊的一種途徑。

以上是CSS中變數的用法介紹(附範例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:博客园。如有侵權,請聯絡admin@php.cn刪除
每周平台新聞:Galaxy Store的Web應用程序,Tappable Stories,CSS Subgrid每周平台新聞:Galaxy Store的Web應用程序,Tappable Stories,CSS SubgridApr 14, 2025 am 11:20 AM

在本週的綜述中:Firefox獲得了類似鎖匠的力量,三星的Galaxy Store開始支持Progressive Web Apps,CSS Subgrid正在Firefox發貨

每周平台新聞:Internet Explorer模式,搜索控制台中的速度報告,限制通知提示每周平台新聞:Internet Explorer模式,搜索控制台中的速度報告,限制通知提示Apr 14, 2025 am 11:15 AM

在本週的綜述中:Internet Explorer進入Edge,Google搜索控制台吹捧新的速度報告,而Firefox給出了Facebook&#039; s Notification

CSS自定義屬性的範圍的功率(和樂趣)CSS自定義屬性的範圍的功率(和樂趣)Apr 14, 2025 am 11:11 AM

您可能至少已經對CSS變量有點熟悉了。如果沒有,這是兩秒鐘的概述:它們真的稱為自定義屬性

我們是程序員我們是程序員Apr 14, 2025 am 11:04 AM

構建網站正在編程。編寫HTML和CSS正在編程。我是程序員,如果您在這裡閱讀CSS-Tricks,那麼您很有可能是您

您如何從網站上刪除未使用的CSS?您如何從網站上刪除未使用的CSS?Apr 14, 2025 am 10:59 AM

在這裡,我想預先知道的是:這是一個很難的問題。如果您降落在這裡,因為您希望指向您可以運行的工具

圖片中的圖片網絡API簡介圖片中的圖片網絡API簡介Apr 14, 2025 am 10:57 AM

圖片中的圖片在2016年發行了Macos Sierra,在Safari瀏覽器中首次出現在網絡上。這使用戶可以彈出

使用Gatsby組織和準備圖像以使圖像模糊效果的方法使用Gatsby組織和準備圖像以使圖像模糊效果的方法Apr 14, 2025 am 10:56 AM

蓋茨比(Gatsby)進行了出色的處理和處理圖像。例如,它可以幫助您節省圖像優化的時間,因為您不必手動

哦,嘿,填充百分比基於父元素的寬度哦,嘿,填充百分比基於父元素的寬度Apr 14, 2025 am 10:55 AM

今天,我學到了一些有關基於百分比的(%)填充的知識,我腦海中完全錯了!我一直認為百分比填充是基於

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具