国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

一文帶你玩轉 CSS 變量

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

CSS 變量是由 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不知道在 里面(因為它不是使用 CSS 在瀏覽器中的 HTML 上下文執行的),也不知道button:hover 是一個按鈕,所以兩個定義的變量都沒有被識別到。

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

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

6、 瀏覽器兼容性

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

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

2022-11-09 09:15:31

ProtoBufGo語言

2023-10-26 16:27:50

前端 WebCSS開發

2023-09-18 08:02:45

CSS布局屬性

2020-11-17 09:32:57

設計模式責任鏈

2022-12-14 08:03:27

CSS變量前端

2023-11-20 08:18:49

Netty服務器

2022-12-20 07:39:46

2023-12-21 17:11:21

Containerd管理工具命令行

2021-11-06 10:18:30

Python變量常量

2023-07-31 08:18:50

Docker參數容器

2021-05-29 10:11:00

Kafa數據業務

2022-11-11 19:09:13

架構

2023-11-06 08:16:19

APM系統運維

2023-11-08 08:15:48

服務監控Zipkin

2022-02-24 07:34:10

SSL協議加密

2023-10-27 08:15:45

2022-09-22 09:00:46

CSS單位

2022-05-16 10:49:28

網絡協議數據

2020-11-27 09:40:53

Rollup前端代碼

2024-05-22 09:45:49

點贊
收藏

51CTO技術棧公眾號

国产精品视频分类| 日韩在线精品| 欧美激情日韩| 成人网在线观看| 欧美精品无码一区二区三区| 在线亚洲伦理| 成人av男人的天堂| 成人精品中文字幕| 国产精品色悠悠| 国产偷激情在线| 6699嫩草久久久精品影院| 欧美精品性视频| www99avcom| 欧美久久久久久一卡四| 国产精品免费精品自在线观看| 久久91精品国产| 国产精品7m凸凹视频分类| 精品婷婷色一区二区三区蜜桃| 国产91在线亚洲| 国产精品美女久久久久久| 久久久久免费精品| 美女少妇精品视频| 成人动漫av在线| 欧美二区在线视频| 亚洲欧美综合网| 小草av在线播放| 在线不卡免费av| 日韩精品社区| 免费一级在线观看播放网址| 1024国产精品| 第一区第二区在线| 蜜桃网站成人| 久久九九全国免费| 蜜桃视频在线免费| 91在线国产电影| 成人avav影音| 偷拍自拍亚洲| 国产精品区一区二区三含羞草| 国产成人精品aa毛片| 国产网友自拍电影在线| 日韩美女av在线| 国产剧情在线观看一区| 中文字幕一区二区三区5566| 久久久久久久9| 亚洲一区电影| 成人短视频在线| 国产一区二区三区久久久久久久久| 爱福利视频一区二区| 久久影院在线观看| 日韩.com| 欧美vide| 精品综合在线| 亚洲人成亚洲人成在线观看图片| 欧美aaa免费| 豆花视频一区二区| 日韩欧美xxxx| 亚洲精品v欧美精品v日韩精品| 欧美日韩老妇| 欧美黑人经典片免费观看| 欧美欧美欧美欧美| 一区二区欧美精品| 亚洲国产福利| 欧美在线亚洲在线| 美女免费视频一区二区| 久久久久久久香蕉| 欧美成人在线免费| 亚洲国产精品久久久久久| 免费a级毛片在线观看| 欧美日韩电影一区二区三区| 亚洲欧美精品中文字幕在线| 免费看成人哺乳视频网站| 国产女人18毛片| 精品视频在线免费| 欧美亚洲激情| 国产写真视频在线观看| 国产美女91呻吟求| 亚洲国产精品国自产拍av| 亚洲福利影院| free亚洲| 欧美激情精品久久久久久久变态 | 亚洲国产高清国产精品| 欧美日韩国产一区在线| 国产 日韩 欧美 综合 一区| 手机亚洲第一页| 中国女人做爰视频| 国产精品美腿一区在线看| 亚洲高清色综合| 久久av最新网址| 骚视频在线观看| 久久久久久久久国产| 国产a区久久久| 欧美亚洲在线日韩| 伊人色综合一区二区三区影院视频| 久久伊人一区二区| 色综合91久久精品中文字幕| 7777精品久久久大香线蕉| 久久久久一区二区三区四区| 国内精品福利| 玖玖综合伊人| 国产综合av在线| 国产精品久久7| 久久777国产线看观看精品| 欧美日韩aaa| 禁久久精品乱码| 国产私人尤物无码不卡| 92国产精品久久久久首页 | 国产精品99久久久久久宅男| 国产网站在线| 亚洲高清视频一区| 欧美最顶级的aⅴ艳星| 日韩av中文在线| 老司机精品久久| 欧美激情综合| 久久人人97超碰com| av一区二区在线播放| 一区二区成人国产精品| 欧美日韩国产丝袜另类| 五月天一区二区三区| 国产99久久久久| 久久久精品久久久久| 四虎884aa成人精品最新| 欧美hdxxx| 深夜福利视频在线免费观看| 成人在线小视频| 欧美国产高跟鞋裸体秀xxxhd| 亚洲国产精品成人一区二区| 天天射综合影视| 国产丝袜欧美中文另类| 亚洲瘦老头同性70tv| 性色av一区二区| 黄色www网站| 水蜜桃一区二区三区| 亚洲一区二区久久| 久久久不卡网国产精品一区| 另类的小说在线视频另类成人小视频在线| 国产精品久久久久久| 天海翼亚洲一区二区三区| 2019中文亚洲字幕| 国外av网站| 日韩福利视频在线| 国产成a人亚洲精v品在线观看| 欧美 日韩 国产在线| 97久久夜色精品国产九色| 亚洲高清不卡av| 91麻豆精品国产91久久久资源速度 | 人在线成免费视频| 男人亚洲天堂网| 色呦呦网站入口| 欧美激情在线观看视频| 亚洲欧洲国产一区| 国产精品短视频| 精品99视频| 成人影院天天5g天天爽无毒影院| 一区二区网站| 超碰97久久| 午夜视频在线免费观看| 亚洲成人自拍| 久久99精品久久久久久久久久 | 美女av免费观看| 特级西西444| 一区二区三区一级片| 99久re热视频精品98| 91国偷自产一区二区三区的观看方式| 黑人巨大精品欧美一区二区| 亚洲黄色片在线观看| 免费成人在线影院| silk一区二区三区精品视频 | 欧美激情精品久久久久久| 久久伊人精品视频| 久久国产色av| 色综合久久中文字幕综合网小说| 久久久精品在线| 欧美激情视频免费观看| 欧美日韩国产成人| 欧美日韩一区小说| 欧美男男同志| 精品一区二区三区欧美| 国产丝袜欧美中文另类| 成人免费视频视频在| 亚洲一卡二卡三卡四卡五卡| 久久精品首页| 天堂va蜜桃一区二区三区| 奇米综合一区二区三区精品视频| 欧美高清视频看片在线观看| 午夜视频成人| 日本理论片午伦夜理片在线观看| 1024在线看片你懂得| 中文另类视频| 户外极限露出调教在线视频| 欧美v在线观看| 美女被啪啪一区二区| 欧美亚洲丝袜| 国产精品美女久久久久久免费| 成人一区二区电影| 久久青青草原| 日韩a级在线观看| 日韩精品一区二区三区丰满| 国产欧美日韩丝袜精品一区| 久久色免费在线视频| 午夜精品久久久久久久99热|