搜尋
首頁web前端css教學css變數說明及教學課程

css變數說明及教學課程

Nov 17, 2017 pm 05:31 PM
css教學

CSS是我們前端開發必不可少的一門語言,能很好的使用它會讓我們的開發變得非常高效,一直以來,CSS中是沒有變量而言的,要使用CSS 變量,只能藉助SASS 或LESS 這類預編譯器。今年三月,微軟宣布 Edge 瀏覽器將支援 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; }
  div { --color: green; }
  #alert { --color: red; }
  * { color: var(--color); }</style><p>蓝色</p><div>绿色</div><div id="alert">红色</div>

上面程式碼中,三個選擇器都宣告了--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變數的知識點,相信大家也已經掌握了很多,希望這篇教學能在工作上幫助大家。

相關教學:

全新知識:CSS變數-variable

第一個CSS變數:currentColor_html/css_WEB-ITnose

CSS變數試玩兒_html/css_WEB-ITnose

#

以上是css變數說明及教學課程的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
'訂閱播客”鏈接應在哪裡?'訂閱播客”鏈接應在哪裡?Apr 16, 2025 pm 12:04 PM

有一段時間,iTunes是播客中的大狗,因此,如果您將“訂閱播客”鏈接到喜歡:

瀏覽器引擎多樣性瀏覽器引擎多樣性Apr 16, 2025 pm 12:02 PM

當他們在2013年去Chrome時,我們失去了歌劇。與Edge今年早些時候也進行了同樣的交易。邁克·泰勒(Mike Taylor)稱這些變化為“減少

網絡共享的UX注意事項網絡共享的UX注意事項Apr 16, 2025 am 11:59 AM

從垃圾點擊誘餌網站到大多數出版物的最多,共享按鈕長期以來一直無處不在。然而,這些

每周平台新聞:Apple部署網絡組件,漸進的HTML渲染,自託管關鍵資源每周平台新聞:Apple部署網絡組件,漸進的HTML渲染,自託管關鍵資源Apr 16, 2025 am 11:55 AM

在本週的綜述中,Apple進入Web組件,Instagram如何插入腳本以及一些思考的食物,以進行自託管關鍵資源。

git Pathspecs以及如何使用它們git Pathspecs以及如何使用它們Apr 16, 2025 am 11:53 AM

當我查看GIT命令的文檔時,我注意到其中許多人都有選擇。我最初以為這只是一個

產品圖像的彩色拾取器產品圖像的彩色拾取器Apr 16, 2025 am 11:49 AM

聽起來有點像一個困難的問題,不是嗎?我們經常沒有成千上萬種顏色的產品鏡頭,以便我們可以隨身攜帶。我們也不是

黑暗模式與React和Themeprovider切換黑暗模式與React和Themeprovider切換Apr 16, 2025 am 11:46 AM

我喜歡網站具有“暗模式”選項時。黑暗模式使我更容易閱讀網頁,並幫助我的眼睛更放鬆。許多網站,包括

帶有HTML對話框元素的一些動手帶有HTML對話框元素的一些動手Apr 16, 2025 am 11:33 AM

這是我第一次查看HTML元素。我已經意識到了一段時間,但是尚未將其旋轉。它很酷,

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.最佳圖形設置
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。