精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

一篇文章帶你玩轉CSS變量

開發 前端
CSS變量即自定義屬性,它包含的值可以在整個文檔中重復使用。下面來看看CSS變量是如何定義和使用的。

大家好,我是 CUGGZ。

CSS 變量由開發者自定義,它包含的值可以在整個文檔中重復使用。下面就來通過這篇文章來更好地理解聲明式 CSS 變量!

1. 基本使用

CSS變量即自定義屬性,它包含的值可以在整個文檔中重復使用。下面來看看CSS變量是如何定義和使用的。

首先,我們要聲明一個自定義屬性,屬性名以兩個減號(--)開始,屬性值可以是任何有效的CSS值,并且這個屬性和其他屬性一樣可以寫在規則集之內:

:root {
--main-bg-color: #C92E33;
}

通常,最佳實踐是將CSS變量定義在根偽類??:root??下,這樣就可以在HTML文檔的任何地方訪問到它了。在使用CSS變量時,使用 ??var()?? 函數包裹所需變量的變量名即可:

div {
background-color: var(--main-bg-color)
}

除了變量名之外,??var()?? 還有第二個參數——備用值。在發現變量值不可訪問的情況下,將使用備用值來代替它:

div {
background-color: var(--main-bg-color, red);
}

對于CSS變量的備用值,在替換的過程中,會有四種可能:

  • 瀏覽器不支持 CSS 變量,帶有var()的代碼行將會被忽略,將使用瀏覽器的默認值;
  • 瀏覽器支持變量,并且該變量設置為正確值,則直接使用該變量;
  • 瀏覽器支持變量,并且變量未設置為任何值,則直接使用備用值;
  • 瀏覽器支持變量,并且該變量設置為無效值,則使用瀏覽器的默認值。

我們甚至可以在媒體查詢中重新設置變量,這些重新設置的值可以在任何地方使用,這是預處理器變量無法實現的:

<div></div>
<div></div>
<div></div>
<div></div>


:root {
--width: 25%;
--margin: 20px;
}

@media (max-width: 400px) {
:root {
--width: 50%;
--margin: 10px;
}
}

body {
display: flex;
flex-wrap: wrap;
}

div {
flex: 1;
height: 220px;
flex-basis: calc(var(--width) - (var(--margin) * 3));
background: #ccc;
margin: var(--margin);
}

CSS 變量使重用和自定義 CSS 代碼成為了可能,因為它們使封裝成為可能。假如我們有一個按鈕,它的 ??class?? 為 flat,代碼如下:

button.flat {
border: 1px solid black;
background: transparent;
color: black;
}

button.flat:hover {
background: black;
color: white;
}

假如我們想要不同的按鈕有不同的操作,比如紅色的按鈕用于危險操作,那么我們就可以使用 ??danger?? 類來覆蓋對應的樣式聲明:

button.flat.danger {
border-color: red;
color: red;
}

button.flat.danger:hover {
background: red;
color: white;
}

如果有很多種顏色和操作,那就需要多次定義樣式來覆蓋之前的樣式。我們可以使用變量來替換顏色:

button {
--color-initial: black;
border: 1px solid var(--color, var(--color-initial));
background: transparent;
color: var(--color, var(--color-initial));
}

button:hover {
background: var(--color, var(--color-initial));
color: white;
}

現在想要主題化這個按鈕,只需要定義??--color??變量即可:

button.flat.danger {
--color: red;
}

這樣就相當于將CSS代碼進行了封裝,代碼簡潔了很多~

2. 作用域

我們可以在全局范圍內聲明 CSS 變量,這些變量可以在整個應用程序中使用。也可以在局部范圍內設置 CSS 變量,它只在特定的選擇器中可用。

(1)CSS 全局變量

要在全局范圍內聲明變量,就要將變量定義在 :??root?? 選擇器中:

:root {
--primary-color: #000;
}

h1 {
color: var(--primary-color);
}

(2)CSS 局部變量

要在局部范圍聲明變量,只需要在選擇器中定義變量即可,這樣聲明的變量只能在該選擇器中使用,如果嘗試在其他地方使用,它不會有任何效果:

h2 {
--h2-color: #999;
color: var(--h2-color);
}

h3 {
color: var(--h2-color); /* 不生效 */
}

(3)優先級和繼承

現在我們知道了,如果在根目錄中定義變量,它將是全局變量,如果在選擇器中定義變量,它將是局部變量。那如果在兩個地方都聲明了同一變量,誰的優先級更高呢?

實際上,CSS變量和JavaScript變量類似,CSS 變量中的局部作用域優先于全局作用域

:root {
--color: red;
}

h2 {
--color: orange;
color: var(--color);
}

這里??<h2>??標簽的內容將是橙色的,因為局部變量的優先級比全局變量的優先級更高。

在CSS中是存在繼承的概念的,對于CSS變量也是如此,如果沒有為元素找到變量,它會從其父元素繼承變量值。下面的??<h2>??標簽的內容也將是橙色的,因為??<h2>??在其選擇器中沒有找到 ??--color?? 變量,所以就會在其父級逐級往上查找這個變量:

:root {
--color: red;
}

body {
--color: orange;
}

h2 {
color: var(--color);
}

3. 注意事項

(1)CSS變量區分大小寫

在定義CSS變量時需要注意,CSS變量的變量名(即屬性名)對大小寫是敏感的,??--my-color?? 和 ??--My-color?? 會被認為是兩個不同的CSS變量。

(2)避免循環依賴

在定義CSS變量時不能出現循環依賴關系,這會導致頁面無法加載:

--variable_name_1 : var(variable_name_2, fallback);
--variable_name_2 : var(variable_name_1, fallback);

(3)CSS 變量不能是屬性名

不能使用 CSS 中的現有屬性作為 CSS 的變量名。例如,我們不能使用名稱“font-size”來初始化變量。

4. 在 JavaScript 中使用

使用 CSS 變量的一大好處就是可以在 JavaScript 中訪問它。

假如我們通過內聯樣式來設置 CSS 變量:

<p style="--color: red"></p>

可以通過以下代碼來獲取變量值:

// 獲取 <p> 元素
const element = document.querySelector('p');

// 檢索CSS變量 --color
element.style.getPropertyValue('--color'); // 'red'

如果在CSS文件中設置CSS變量:

p {
--color: red;
}

就需要通過以下形式來獲取變量值:

// 獲取 <p> 元素
const element = document.querySelector('p');

// 獲取CSS變量 --color
getComputedStyle(element).getPropertyValue('--color'); // 'red'

當然也可以使用這種形式來獲取變量值:

<p style="--color: red"></p>

// 獲取 <p> 元素
const element = document.querySelector('p');

// 獲取CSS變量 --color
getComputedStyle(element).getPropertyValue('--color'); // 'red'

可以通過以下形式使用JavaScript來設置CSS變量:

// 獲取 <p> 元素
const element = document.querySelector('p');

// 將 --color 變量設置為 blue
element.style.setProperty('--color', 'blue');

5. SASS 變量 vs CSS 變量

下面來看看 CSS 變量出現之前都是如何做的。在CSS變量出現之前開發人員會使用 SASS 變量,它們的目的是相似的,但是不夠流暢和靈活。

SASS 變量在定義時需在變量名前加上“$”,在使用變量時直接使用變量名即可:

$main-bg-color: #C92E33;

background-color: $main-bg-color;

SASS 的問題就在于它是一個預處理器,所以,任何在 SASS 中聲明的變量都需要經過編譯才能執行。上面的代碼就會編譯成這樣:

background-color: #C92E33;

這樣才是有效的CSS,代碼經過編譯后,變量也就消失了。因此,我們不能在 CSS 運行時更改變量值。

預處理器中的變量范圍歸結為嵌套的大括號塊。然而,因為 CSS 變量是屬性,所以它們的作用域是基于 DOM 的。這意味著 CSS 變量是按元素解析的,而不是按作用域解析的,來看下面的例子:

body {
--shadow-color: red;
}

button {
box-shadow: 1px 1px 1px var(--shadow-color);
}

button:hover {
--shadow-color: blue;
}

當我們將鼠標懸停在按鈕上時,按鈕的紅色變為了藍色。那使用預處理器語言 SASS 會是什么結果呢,來看代碼:

body {
$shadow-color: gray;
}

button {
box-shadow: 1px 1px 1px $shadow-color;
}

button:hover {
$shadow-color: blue;
}

這樣就會出現語法錯誤,第六行使用了未定義的變量。因為SASS不知道 ??<button>?? 在 ??<body>?? 里面(因為它不是使用 CSS 在瀏覽器中的 HTML 上下文執行的),也不知道button:hover 是一個按鈕,所以兩個定義的變量都沒有被識別到。

CSS 變量與預處理器變量最重要的區別就是CSS變量是動態分配的。它們在頁面的整個生命周期中保持活動狀態,當更新它們時,所有引用它們的地方都會更新。因為它們是屬性,所以可以通過任何更新 CSS 屬性的機制來更新它們:樣式表、內聯樣式,甚至 JavaScript。

下面是 CSS 變量和 SASS 變量的主要區別:

圖片

6. 瀏覽器兼容性

目前,CSS 變量已經得到了各大瀏覽器的支持:

圖片

責任編輯:姜華 來源: 前端充電寶
相關推薦

2021-01-26 23:46:32

JavaScript數據結構前端

2023-09-06 14:57:46

JavaScript編程語言

2020-11-03 19:18:28

CSS對齊文本

2021-05-31 09:30:36

Css前端CSS 特效

2021-01-25 05:39:54

Css前端Border

2021-04-07 06:11:37

Css前端CSS定位知識

2020-11-17 11:10:21

CSS選擇器HTML

2022-02-21 09:44:45

Git開源分布式

2021-06-30 00:20:12

Hangfire.NET平臺

2023-05-12 08:19:12

Netty程序框架

2020-11-27 08:51:29

CSSOpacity透明度

2020-12-18 05:40:37

CSS clearHtml

2021-05-20 09:02:59

CSS單位長度

2023-06-28 15:04:59

CSSHTML

2022-03-04 09:31:41

CSS前端屬性選擇器

2023-08-01 14:34:12

HTMLCSS

2022-02-15 09:31:43

透明度CSS

2020-10-22 11:15:47

Go語言變量

2021-09-29 10:00:07

Go語言基礎

2021-10-13 10:00:52

Go語言基礎
點贊
收藏

51CTO技術棧公眾號

婷婷在线精品视频| 精品久久久久久中文字幕2017| 精品区在线观看| 亚洲三级网站| 亚洲无线码在线一区观看| 欧美午夜aaaaaa免费视频| 国产一区久久精品| 成人精品免费网站| 国产精品igao视频| 天天色影综合网| 嫩草国产精品入口| 欧美久久久久久久久中文字幕| 欧美视频在线第一页| 男人久久精品| 国产精品99久久久久久久女警| 久久久久久久一区二区| 免费黄在线观看| 99亚洲乱人伦aⅴ精品| 五月天一区二区| 中国成人在线视频| 少妇性bbb搡bbb爽爽爽欧美| 极品少妇一区二区三区精品视频 | 日韩三级在线观看| 男女啪啪网站视频| h片在线观看视频免费免费| 中文字幕不卡在线观看| 精品国产乱码久久久久久久软件| 中文字幕人妻一区二区三区视频| 日韩视频精品在线观看| 久久久精品日本| 免费看日本黄色片| 亚洲国产欧美日韩在线观看第一区| 欧美丰满一区二区免费视频| 99re在线视频免费观看| 丁香花在线电影小说观看| 亚洲欧洲精品一区二区三区 | 一区二区三区四区日韩| 亚洲精品综合精品自拍| 亚洲欧洲国产视频| 国产精品亚洲欧美一级在线| 在线观看区一区二| 92看片淫黄大片一级| 看黄在线观看| 五月天激情小说综合| 少妇久久久久久被弄到高潮| 日本电影全部在线观看网站视频| 国产欧美一区在线| 欧美一区二区三区电影在线观看| 神马久久久久久久久久| 岛国av在线一区| 成人在线看片| 老司机午夜福利视频| 床上的激情91.| 国产成人一区二区三区免费看| 99热这里只有精品9| 国内精品写真在线观看| 国产区精品在线观看| 在线亚洲欧美日韩| 久久精品国产77777蜜臀| 国产日韩亚洲欧美| 国产精品高潮呻吟久久久| 精品在线播放免费| 91热精品视频| www男人的天堂| 成人午夜免费av| 国产麻豆乱码精品一区二区三区| 国产 欧美 自拍| 波多野结衣中文一区| 国产一区精品视频| 日韩av视屏| 国产欧美日韩另类视频免费观看| 偷拍视频一区二区| 免费黄色网页在线观看| 亚洲欧美另类图片小说| 日韩a级黄色片| 成人bbav| 欧美在线观看你懂的| 久久久久久久久久一区| 亚洲一区二区三区免费| 日韩成人免费视频| 免费在线观看a视频| 91精品综合| 国内精品400部情侣激情| 国产成人精品一区二三区| 午夜在线视频观看日韩17c| 国产精品第3页| 国产麻豆免费视频| www.性欧美| 亚洲国产欧美日韩| 在线视频观看国产| 一本色道久久综合狠狠躁的推荐| 日本激情综合网| www.成人在线.com| 亚洲黄色在线看| 国产视频123区| 韩国欧美一区| 国产精品久久久久久久久久久久| 精品国产亚洲AV| 久久久99精品免费观看| 男人的天堂视频在线| 手机av在线| 91精品国产综合久久香蕉的特点| 中文字幕在线播放一区| 国产99亚洲| 欧美片一区二区三区| 亚洲欧美另类在线视频| 国产精品18久久久久久久久| 欧美日韩亚洲在线| 金瓶狂野欧美性猛交xxxx| 日本精品一区二区三区高清| 国产a级片视频| 精品国产一区二区三区噜噜噜| 欧美极品少妇xxxxⅹ喷水| www.久久网| 91网站在线播放| 日韩一级免费看| 香蕉久久久久久| 国产一区二区激情| 日韩大片免费在线观看| 韩国一区二区三区| 日韩欧美一区二区三区四区五区| www在线观看黄色| 日韩精品一区二区三区视频播放| 激情五月深爱五月| 久久久久久穴| 久久伊人一区| sm捆绑调教国产免费网站在线观看| 欧美日韩国产美| 国产精品815.cc红桃| 亚洲东热激情| 国产91视觉| 综合图区亚洲| 日韩一级大片在线| 爱爱视频免费在线观看| 捆绑紧缚一区二区三区视频| 日韩aⅴ视频一区二区三区| 欧美调教sm| 亚洲国产精品99久久| 免费一级片在线观看| 精品一区二区三区免费观看 | av在线播放网址| 欧美日韩少妇| 国产成人亚洲欧美| 丁香花在线影院| 精品国产制服丝袜高跟| 欧美精品一级片| 国产成人在线色| 一级黄色片播放| 亚洲一区网址| 久久久久久一区二区三区| a天堂在线视频| 中文字幕一区日韩精品欧美| 国产精品一区二区羞羞答答| 欧洲杯半决赛直播| 国产精品免费福利| 天堂а√在线资源在线| 在线观看91av| 欧美日韩在线视频免费| 国产成人av福利| 欧美激情亚洲天堂| 乱中年女人伦av一区二区| 91精品国产高清自在线| 日韩一区av| 欧美午夜在线一二页| 自拍偷拍第9页| 国产一二精品视频| 美女黄色免费看| 日韩美脚连裤袜丝袜在线| 日本亚洲精品在线观看| 日本在线观看网站| 精品国产亚洲在线| 九九热在线免费观看| 国产日韩欧美精品电影三级在线| av在线无限看| 综合精品一区| 精品久久中出| 本网站久久精品| 欧美成人一区在线| 天天干天天爽天天操| 在线观看视频一区二区| 欧洲猛交xxxx乱大交3| 99久久久无码国产精品| 另类小说第一页| 欧美色123| 日韩免费电影一区二区| 成人在线精品| 欧美一二三视频| 99免在线观看免费视频高清| 日韩欧美中文字幕一区| 一级片中文字幕| 综合亚洲深深色噜噜狠狠网站| 中国特级黄色片| 日韩高清欧美激情| 97av中文字幕| 欧美精品乱码| 国产高清不卡av| 99riav视频一区二区| 欧美激情精品久久久久久变态| 欧美孕妇性xxxⅹ精品hd| 7777精品伊人久久久大香线蕉的 | 俄罗斯毛片基地| 懂色av一区二区三区蜜臀| 国产成人综合一区| 亚洲视频一区| 日韩一本精品| 欧美电影免费网站| 91九色国产社区在线观看| 日韩深夜视频| 欧美成人午夜激情在线| 91最新在线| 亚洲男女性事视频| 精品人妻伦一二三区久久| 日本韩国欧美在线| 国产午夜精品无码| 亚洲欧美视频在线观看视频| xxxxx在线观看| www.亚洲国产| 中文字幕乱妇无码av在线| 麻豆一区二区三区| 黄色av免费在线播放| 99视频一区| 日本五级黄色片| 在线中文字幕第一区| 亚洲激情图片| 亚洲素人在线| 久久精品人人做人人爽电影| 北条麻妃一区二区三区在线| 91欧美精品成人综合在线观看| 三上悠亚亚洲一区| 欧美自拍视频在线| 1234区中文字幕在线观看| 九九久久精品一区| av网址在线看| 久久香蕉国产线看观看av| 天天综合视频在线观看| 宅男66日本亚洲欧美视频| 国产原创av在线| 亚洲欧美另类在线观看| 五月婷婷激情在线| 欧美精品一区二区三区高清aⅴ | 国产亚洲视频中文字幕视频| 日本aaa在线观看| 亚洲精品自拍视频| 免费福利在线视频| 亚洲欧美日韩精品| 亚洲av激情无码专区在线播放| 精品日韩在线观看| 亚洲第一天堂在线观看| 精品少妇一区二区三区在线播放 | 懂色av一区二区三区免费看| 日本泡妞xxxx免费视频软件| 成人性视频网站| 亚洲男人在线天堂| 久久午夜色播影院免费高清| 国产色视频一区二区三区qq号| 久久午夜老司机| 亚洲AV无码成人精品区明星换面| 中文久久乱码一区二区| 人妻无码一区二区三区免费| 中文字幕在线不卡一区二区三区| 91久久国产综合| 亚洲一区二区av在线| 国产精品白浆一区二小说| 亚洲成av人**亚洲成av**| 国产精品黄色大片| 在线观看区一区二| 国产精品视频在线观看免费| 日韩一区二区免费在线电影| 日韩在线观看视频一区二区三区| 亚洲精品电影网站| 番号在线播放| 精品国偷自产在线视频99| 色呦呦在线播放| 91成人精品网站| 日韩在线观看不卡| 91日本视频在线| 精品久久ai电影| 日韩视频精品| 欧美另类综合| 色婷婷综合久久久久中文字幕| 久久精品国产精品亚洲综合| 日本美女视频网站| 久久久久久久久久久电影| 日韩av网站在线播放| 亚洲国产视频在线| 中文字幕精品视频在线观看| 91精品国产综合久久蜜臀 | 成人黄色毛片| 91超碰在线免费观看| 久久超碰99| 宅男一区二区三区| 国产精品毛片| 在线视频观看91| 91在线播放网址| 潘金莲一级黄色片| 丁香五六月婷婷久久激情| 夜夜狠狠擅视频| 亚洲精品电影网站| 成人在线视频亚洲| 日本国产精品视频| 欧美日本三级| 天天综合色天天综合色hd| 中文字幕一区二区三区乱码图片 | 日本一区二区三区四区五区| 欧美色爱综合网| 五月婷婷狠狠干| 欧美成人在线网站| 国产超碰精品| 国产精品一区视频| 66视频精品| 成人性做爰aaa片免费看不忠| 国产sm精品调教视频网站| 东方伊人免费在线观看| 五月天一区二区三区| 99久久精品国产一区色| 伊人久久五月天| 美女网站在线看| 99国产超薄丝袜足j在线观看 | 亚洲系列第一页| 日韩毛片在线看| 丁香高清在线观看完整电影视频 | 精品国自产在线观看| 一区二区三区亚洲| 日本在线播放一二三区| 国产91aaa| 欧美ab在线视频| 亚洲视频一二三四| 国产日韩欧美a| 草莓视频18免费观看| 亚洲精品电影在线| 狼人综合视频| 精品久久蜜桃| 亚洲少妇在线| 欧美大片免费播放器| 亚洲国产精品一区二区尤物区| 国产日韩欧美中文字幕| 日韩视频在线免费观看| 国外成人福利视频| 色999日韩自偷自拍美女| 久久午夜视频| 久久精品国产亚洲AV熟女| 狠狠色狠色综合曰曰| 瑟瑟在线观看| 日韩免费观看av| 红桃成人av在线播放| 99久久国产宗和精品1上映| 久久婷婷成人综合色| 美女又爽又黄免费视频| 亚洲欧美国产一区二区三区| 在线天堂资源www在线污| 蜜桃91精品入口| 久久夜色精品| 日本理论中文字幕| 欧美日本乱大交xxxxx| 免费观看久久久久| 2019国产精品视频| 国产一区二区三区四区老人| 性欧美18—19sex性高清| 性感美女极品91精品| 免费在线黄色影片| 国产精品成人av性教育| 日韩a一区二区| 天美一区二区三区| 亚洲午夜免费视频| 三级无遮挡在线观看| 国产精品wwww| 99视频精品全部免费在线视频| 亚洲精品中文字幕乱码无线| 亚洲一区二区三区在线播放| 亚洲av毛片成人精品| 国产精品美女免费| 欧美阿v一级看视频| 亚洲天堂美女视频| 91黄视频在线观看| 爆操欧美美女| 精品国产一区二区三区麻豆小说| 午夜亚洲一区| 影音先锋男人资源在线观看| 日韩午夜激情视频| 麻豆免费在线| 亚洲无玛一区| 成人免费视频国产在线观看| 午夜婷婷在线观看| 另类专区欧美制服同性| 蜜桃一区av| 我看黄色一级片| 一区二区三区欧美日韩| 日本在线视频1区| 成人福利在线观看| 亚洲日本视频| 国产中文字幕久久| 亚洲福利在线视频| 成人全视频免费观看在线看| 国产自产在线视频| 中文字幕电影一区| 天堂v在线观看| 国产日本欧美一区二区三区| 99精品国产福利在线观看免费 | 一区二区日韩av| 成人免费视频|