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

一文帶你玩轉(zhuǎn) CSS 變量

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

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

1、基本使用

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

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

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

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

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

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

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

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

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

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

<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 類來覆蓋對應(yīng)的樣式聲明:

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;
}

現(xiàn)在想要主題化這個按鈕,只需要定義--color變量即可:

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

這樣就相當(dāng)于將CSS代碼進(jìn)行了封裝,代碼簡潔了很多。

2、 作用域

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

(1)CSS 全局變量

要在全局范圍內(nèi)聲明變量,就要將變量定義在 :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)優(yōu)先級和繼承

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

實際上,CSS變量和JavaScript變量類似,CSS 變量中的局部作用域優(yōu)先于全局作用域。

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

這里<h2> 標(biāo)簽的內(nèi)容將是橙色的,因為局部變量的優(yōu)先級比全局變量的優(yōu)先級更高。 在CSS中是存在繼承的概念的,對于CSS變量也是如此,如果沒有為元素找到變量,它會從其父元素繼承變量值。下面的<h2> 標(biāo)簽的內(nèi)容也將是橙色的,因為 <h2>在其選擇器中沒有找到 --color 變量,所以就會在其父級逐級往上查找這個變量:

:root {
--color: red;
}
body {
--color: orange;
}
h2 {
color: var(--color);
}

3、 注意事項

(1)CSS變量區(qū)分大小

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

(2)避免循環(huán)依賴

在定義CSS變量時不能出現(xiàn)循環(huán)依賴關(guān)系,這會導(dǎo)致頁面無法加載:

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

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

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

4、 在 JavaScript 中使用

使用 CSS 變量的一大好處就是可以在 JavaScript 中訪問它。假如我們通過內(nèi)聯(lián)樣式來設(shè)置 CSS 變量:

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

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

// 獲取 <p> 元素
const element = document.querySelector('p');
// 檢索CSS變量 --color
element.style.getPropertyValue('--color'); // 'red'

如果在CSS文件中設(shè)置CSS變量:

p {
--color: red;
}

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

// 獲取 <p> 元素
const element = document.querySelector('p');
// 獲取CSS變量 --color
getComputedStyle(element).getPropertyValue('--color'); // 'red'

當(dāng)然也可以使用這種形式來獲取變量值:

<p style="--color: red"></p>
// 獲取 <p> 元素
const element = document.querySelector('p');
// 獲取CSS變量 --color
getComputedStyle(element).getPropertyValue('--color'); // 'red'

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

// 獲取 <p> 元素
const element = document.querySelector('p');
// 將 --color 變量設(shè)置為 blue
element.style.setProperty('--color', 'blue');

5、 SASS 變量 vs CSS 變量

下面來看看 CSS 變量出現(xiàn)之前都是如何做的。在CSS變量出現(xiàn)之前開發(fā)人員會使用 SASS 變量,它們的目的是相似的,但是不夠流暢和靈活。SASS 變量在定義時需在變量名前加上“$”,在使用變量時直接使用變量名即可:

$main-bg-color: #C92E33;
background-color: $main-bg-color;

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

background-color: #C92E33;

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

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

body {
--shadow-color: red;
}
button {
box-shadow: 1px 1px 1px var(--shadow-color);
}
button:hover {
--shadow-color: blue;
}

當(dāng)我們將鼠標(biāo)懸停在按鈕上時,按鈕的紅色變?yōu)榱怂{(lán)色。那使用預(yù)處理器語言 SASS 會是什么結(jié)果呢,來看代碼:

body {
$shadow-color: gray;
}
button {
box-shadow: 1px 1px 1px $shadow-color;
}
button:hover {
$shadow-color: blue;
}

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

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

下面是 CSS 變量和 SASS 變量的主要區(qū)別:

6、 瀏覽器兼容性

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

責(zé)任編輯:姜華 來源: 前端充電寶
相關(guān)推薦

2022-11-09 09:15:31

ProtoBufGo語言

2023-10-26 16:27:50

前端 WebCSS開發(fā)

2023-09-18 08:02:45

CSS布局屬性

2020-11-17 09:32:57

設(shè)計模式責(zé)任鏈

2022-12-14 08:03:27

CSS變量前端

2021-11-06 10:18:30

Python變量常量

2023-11-20 08:18:49

Netty服務(wù)器

2022-12-20 07:39:46

2023-12-21 17:11:21

Containerd管理工具命令行

2023-07-31 08:18:50

Docker參數(shù)容器

2023-11-06 08:16:19

APM系統(tǒng)運維

2021-05-29 10:11:00

Kafa數(shù)據(jù)業(yè)務(wù)

2022-11-11 19:09:13

架構(gòu)

2022-09-22 09:00:46

CSS單位

2023-10-27 08:15:45

2023-11-08 08:15:48

服務(wù)監(jiān)控Zipkin

2022-02-24 07:34:10

SSL協(xié)議加密

2022-05-16 10:49:28

網(wǎng)絡(luò)協(xié)議數(shù)據(jù)

2023-03-06 21:29:41

mmap技術(shù)操作系統(tǒng)

2020-11-27 09:40:53

Rollup前端代碼
點贊
收藏

51CTO技術(shù)棧公眾號

欧美丝袜美腿| 欧美大胆的人体xxxx| 免费国产亚洲视频| 久久偷看各类女兵18女厕嘘嘘| 国产美女18xxxx免费视频| 在线看女人毛片| 91免费观看国产| 国产精品视频精品视频| 久久国产精品二区| 免费精品国产| 欧美疯狂性受xxxxx喷水图片| 奇米777四色影视在线看| 视频在线不卡| 国产一区二区导航在线播放| 欧美一乱一性一交一视频| 亚洲欧美卡通动漫| 日韩三级av| 制服.丝袜.亚洲.另类.中文| 久草资源站在线观看| 免费大片在线观看www| 91丨国产丨九色丨pron| 亚洲最大的网站| 国产性生活视频| 尤物在线精品| 久久成人av网站| 国产精品理论在线| 亚洲精品456| 亚洲精品在线电影| 韩国一区二区在线播放| 99蜜月精品久久91| 亚洲午夜免费电影| 天天干天天色天天爽| 国产一区精品| 2020日本不卡一区二区视频| 成人在线观看网址| 国产乱淫av免费| 裸体在线国模精品偷拍| 国产不卡av在线免费观看| 国产精品自拍视频一区| 中文在线日韩| 久久视频免费在线播放| 五月激情四射婷婷| 精品国产视频| 国产日韩一区二区三免费高清| 国产自产v一区二区三区c| 国产成人精品电影| 影音先锋在线国产| 99在线观看免费视频精品观看| 欧美精品性视频| 精品无码久久久久成人漫画| 久久理论电影| 久久精品国产亚洲7777| 久久精品在线观看视频| 久久精品国产99久久| 一本一本久久a久久精品综合小说 一本一本久久a久久精品牛牛影视 | 亚洲香蕉成视频在线观看| 大地资源二中文在线影视观看| 国产精伦一区二区三区| 亚洲国产日韩精品在线| 一起草在线视频| 亚洲人亚洲人色久| 亚洲人成网站777色婷婷| a级在线免费观看| 成人嫩草影院| 日韩一区二区精品视频| 免费看一级大片| 国产精品av久久久久久麻豆网| 久久久久国产精品免费网站| 日本网站免费观看| 蜜乳av另类精品一区二区| 国产成人a亚洲精品| 涩涩视频在线观看| 国模一区二区三区白浆| 国产高清一区二区三区| 天堂а在线中文在线无限看推荐| 久久久一区二区三区捆绑**| 色播五月综合| 成人av福利| 亚洲精品无遮挡| 欧美综合国产| 国产精品情侣自拍| 国产精品毛片一区视频播 | www.男人天堂| 欧美日韩国产一区二区三区不卡 | 日韩一区二区三区四区| 性活交片大全免费看| 日韩欧美黄色| 久久久成人的性感天堂| 在线观看免费国产视频| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲bt天天射| 欧美日韩视频精品二区| 亚洲色图视频网| 欧美极品欧美精品欧美| 欧美亚洲人成在线| 亚洲国产女人aaa毛片在线| 永久免费成人代码| 午夜日韩在线| 国产成人精品最新| www久久久com| 中文字幕精品—区二区四季| 99色这里只有精品| 外国成人毛片| 亚洲欧美日韩精品久久亚洲区| 永久免费看片直接| 午夜亚洲激情| av成人观看| 69av在线| 日韩欧美成人网| 午夜性福利视频| 欧美三级情趣内衣| 久久久天堂国产精品女人| 在线视频1卡二卡三卡| 99精品热视频| 亚洲一区 在线播放| av在线日韩| 日韩国产精品视频| 久草网站在线观看| 麻豆国产精品视频| 欧美日韩一区二区三区免费| 国产精品186在线观看在线播放| 欧美系列日韩一区| 国产精品毛片一区二区| 1024成人| 超碰97国产在线| 国产最新在线| 欧美日韩国产精品成人| 国产女主播喷水高潮网红在线| 在线看片日韩| 国产精品乱码| 一色桃子av在线| 777午夜精品免费视频| 调教驯服丰满美艳麻麻在线视频 | 一区二区xxx| 亚洲瘦老头同性70tv| 97国产精品视频人人做人人爱| 国产黄色大片网站| 亚洲美女一区二区三区| 色综合五月婷婷| 国产精品毛片一区二区在线看| 国产精品激情av电影在线观看| 日本一级在线观看| 狠狠躁夜夜躁人人爽天天天天97| 中文字幕第3页| 亚洲精品一级| 久久精品一区二区三区不卡免费视频| av电影在线免费| 亚洲精品福利视频| 日韩不卡在线播放| 久久久久久亚洲综合影院红桃| 日韩人妻精品无码一区二区三区| 日韩有码中文字幕在线| 欧美亚洲伦理www| 久久精品蜜桃| 欧美视频三区在线播放| 毛片视频免费播放| 精品影院一区二区久久久| 一级黄色录像免费看| 欧美日韩黄网站| 欧美激情视频一区| 网站黄在线观看| 91福利精品视频| eeuss中文字幕| 国产一区二区三区四区五区美女| 麻豆一区二区三区在线观看| 91久久偷偷做嫩草影院电| 久久人人看视频| 黄色在线免费观看大全| 欧美日韩久久久一区| 黑鬼狂亚洲人videos| 成人性生交大片免费| av免费播放网址| 久久中文亚洲字幕| 春色成人在线视频| 国产精品迅雷| 久久久国产精品亚洲一区| 国产77777| 在线亚洲一区观看| av激情在线观看| 91在线一区二区三区| 男操女免费网站| 国产综合亚洲精品一区二| 精品一区久久久| 成人性片免费| 久久99久久久久久久噜噜| 日本一卡二卡四卡精品 | 中文字幕国产高清| 99精品热6080yy久久| 亚洲国产日韩美| 红杏aⅴ成人免费视频| 国产精品看片资源| 成人性生交大片免费看在线播放| 亚洲性猛交xxxxwww| www.五月婷婷| 欧美日韩国产一级| 成人精品免费在线观看| 国产91精品免费| 亚洲www在线| 国模私拍一区二区国模曼安| 国产亚洲一区精品| 亚洲国产精品久久久久爰性色| 欧美午夜无遮挡| 少妇视频一区二区| 91蝌蚪porny九色| 久久精品视频在线观看免费| 久久久一二三| 欧美乱做爰xxxⅹ久久久| 欧美艳星介绍134位艳星| 国产欧美日韩综合一区在线观看 | 日本国产一区二区| 国产午夜激情视频| 日韩毛片一二三区| 日韩视频在线观看免费视频| 99精品黄色片免费大全| 国产sm在线观看| 蜜桃一区二区三区在线| 日韩免费一级视频| 好吊视频一区二区三区四区| 亚洲黄色成人久久久| 欧美午夜寂寞| 国产精品日韩一区二区| 日本成人手机在线| 国产一区二区在线免费| 欧美暴力调教| 欧美一区二区三区免费视| 男人添女人下部高潮视频在线观看| 中文字幕亚洲综合久久| 国产在线视频福利| 亚洲欧美色图片| 日本黄色免费视频| 精品伦理精品一区| 精品人妻久久久久一区二区三区| 91 com成人网| 亚洲一级在线播放| 欧美亚洲动漫精品| 亚洲 国产 日韩 欧美| 岛国av一区二区三区| 天天综合网入口| 欧美日韩国产一区在线| 日本特黄一级片| 亚洲高清免费观看高清完整版在线观看| 国产精品久久久精品四季影院| 国产精品大尺度| 91久久久久久久久久久久久久 | 亚洲激情一区二区| 日本女优一区| 在线观看亚洲视频啊啊啊啊| 91久久电影| 日韩成人午夜影院| 欧美午夜不卡| 欧美三级在线观看视频| 夜夜精品视频| 免费看a级黄色片| 青青青伊人色综合久久| 成人日韩在线视频| 国产成人午夜片在线观看高清观看| 最好看的中文字幕| 成人禁用看黄a在线| 中文在线一区二区三区| 久久综合给合久久狠狠狠97色69| 精品国产无码在线观看| 国产精品无码永久免费888| 91香蕉国产视频| 亚洲精品乱码久久久久| 国产一级一片免费播放| 天天综合网天天综合色| 国产一级片免费在线观看| 欧美日韩国产一二三| www.成人在线观看| 亚洲精品久久久久久久久久久久久 | 美腿丝袜亚洲三区| 无码人妻少妇色欲av一区二区| 岛国av在线一区| 亚洲午夜福利在线观看| 国产精品久久久久影院色老大| 日韩在线观看视频一区二区| 亚洲va欧美va天堂v国产综合| 无码人妻av免费一区二区三区 | 你懂的在线看| yellow中文字幕久久| 免费毛片在线看片免费丝瓜视频 | 成人精品视频在线观看| 国产成人精品福利一区二区三区 | 91精品尤物| 日本一区二区在线视频| 亚洲中无吗在线| 日韩精品视频一区二区在线观看| 精油按摩中文字幕久久| 国产二级一片内射视频播放| 国产欧美一二三区| 久艹视频在线观看| 欧美私模裸体表演在线观看| 亚洲高清精品视频| 一区二区在线免费视频| 欧美videosex性欧美黑吊| 国产国语刺激对白av不卡| 视频精品一区二区三区| 色中色综合成人| 亚洲国产二区| 极品粉嫩美女露脸啪啪| 久久综合久久久久88| 青草影院在线观看| 在线一区二区三区四区五区| 欧洲成人一区二区三区| 日韩在线观看免费av| 综合久久2023| 国产精品毛片va一区二区三区| 欧美岛国激情| 女人另类性混交zo| 成人午夜av在线| 婷婷伊人五月天| 欧美色电影在线| 你懂的在线观看| 91sa在线看| aaa国产精品视频| 国产免费xxx| 麻豆久久一区二区| 国产小视频自拍| 欧美日韩亚洲视频一区| 丰满人妻一区二区三区四区53| 日韩在线中文字幕| 成人在线黄色| 欧美性色黄大片人与善| 国产日韩亚洲| 99久久免费看精品国产一区| 尤物在线观看一区| 国产情侣激情自拍| 综合国产在线观看| 国产精成人品2018| 欧美专区一二三| 国产情侣一区| 欧美成人三级伦在线观看| 亚洲图片欧美视频| 性欧美8khd高清极品| 欧美精品亚州精品| 日韩区欧美区| 国产亚洲精品久久久久久久| 国产一区二区三区日韩| 亚洲av鲁丝一区二区三区| 欧美精品v国产精品v日韩精品| 91ph在线| 91亚洲午夜在线| 伊人久久大香线| 日本wwww色| 亚洲国产日日夜夜| 五十路在线视频| 欧美一级bbbbb性bbbb喷潮片| 亚洲警察之高压线| 日韩精品一区二区三区色欲av| 国产亚洲一区二区三区| 国产精品日韩欧美综合| 182在线视频观看| 国产免费一区二区| 国产精品老牛| 国产精品揄拍100视频| 色综合婷婷久久| www免费网站在线观看| 国产精品天天狠天天看| 国产大片一区| 亚洲911精品成人18网站| 亚洲444eee在线观看| 日本国产在线| 国产精品网站视频| 你懂的国产精品| 久久久午夜精品福利内容| 精品动漫一区二区| 美国一级片在线免费观看视频| 国产精品日韩久久久久| 午夜欧美精品| 黄色a一级视频| 欧美三级日韩三级| 中文字幕有码在线视频| 激情视频一区二区| 三级在线观看一区二区| 粉嫩av性色av蜜臀av网站| 日韩精品一区二| 伊人久久国产| www.-级毛片线天内射视视| 成人动漫精品一区二区| 久久久久久久久久成人| 久久深夜福利免费观看| 欧美日韩另类图片| 中文字幕 日韩 欧美| 亚洲一区二区四区蜜桃| 麻豆影视在线| 99久久国产免费免费| 久久中文在线| 久久婷婷综合国产| 伊人激情综合网| 亚洲天堂av资源在线观看| 女人另类性混交zo| 亚洲一二三四在线| 在线免费观看黄色网址| 国产精品夜夜夜一区二区三区尤| 三级在线观看一区二区| 国产精品suv一区二区| 在线视频欧美性高潮| 欧美五码在线| 亚洲欧美激情一区二区三区| 91精品1区2区|