前面的話
一直以來,CSS中是沒有變數而言的,要使用 CSS 變量,只能藉助 SASS 或 LESS 這類預編譯器。新的草案發布之後,直接在 CSS 中定義和使用變數不再是幻想了。本文將詳細介紹CSS變數variable
CSS 變量,顧名思義,也就是由網頁的作者或使用者定義的實體,用來指定文件中的特定變數。
更準確的說法,應該稱為 CSS 自訂屬性 ,不過下文為了好理解都稱為 CSS 變數。
一直以來我們都知道,CSS 中是沒有變數而言的,要使用 CSS 變量,只能藉助 SASS 或 LESS 這類預編譯器。
但是新的草案發布之後,直接在CSS 中定義和使用變數已經不再是幻想了,像下面這樣,看個簡單的例子:
// 宣告一個變數:
:root{
--bgColor:#000;
##} 這裡我們藉助了上篇文章 結構性偽類 中的 :root{ } 偽類,在全域 :root{ } 偽類定義了一個CSS 變量,並取名為 --bgColor 。 定義完了之後則是使用,假設我要設定一個div 的背景色為黑色: .main{--開頭。例如--example-variable: 20px,意思是將20px賦值給--example-varibale變數
:root{ --bgColor:#000; }變數宣告就像變普通的樣式宣告語句一樣,也可以使用內聯樣式 # 變量宣告語句必須包含一個元素內,而不能隨意放置
//错误 <style> --bgColor:#000; </style>【使用變數】 使用var()函數使用變量,並且可以使用在任意的地方。例如:var(--example-variable)會傳回--example-variable所對應的值
<div></div>
<div></div>
##
繼承和層疊
和普通的樣式屬性一樣,變數屬性也支援繼承和層疊。在下列範例中,body元素的變數值為green,div元素的變數值為red; 基於層疊的原理,最終div元素的背景顏色為紅色
<div></div>
組合與計算
【組合】
CSS 變數可以進行組合使用
<style>.box{--top:20%;--left:30%;width: 100px;height: 100px;background-image: url(img/24/xiaoshu.jpg);background-position: var(--left) var(--top);}</style><div></div>
<style>.box{--color1:#;--color2:333;width: 100px;height: 100px;background-color: var(--color1)var(--color2);}</style><div></div>【計算】 變數和普通樣式值一樣,除了組合,還可以使用calc進行計算
<style>.box{--borderWidth:2px;width: 100px;height: 100px;background-color:lightblue;border-left: calc(var(--borderWidth) * 2) solid black;}</style><div></div>
<div></div> <script> var oBox = document.getElementById('box'); console.log(oBox.style['--color']); //undefined</script>【getPropertyValue()】
<div></div> <script> var oBox = document.getElementById('box'); console.log(oBox.style.getPropertyValue('--color'));//'lightgreen'</script>【setProperty()】
<div></div> <script>var oBox = document.getElementById('box');var oBtn = document.getElementById('btn'); oBtn.onclick = function(){ oBox.style.setProperty('--color','lightblue'); }</script>
.box{ --color:red; width: 100px; height: 100px; background-color:--color !important; }<div></div>chrome瀏覽器截圖如下

:root{ --mainColor:#fc0; } .div1{ color:var(--mainColor); } .div2{ color:var(--mainColor); }###
2、语义化
变量的第二个优势就是名称本身就包含了语义的信息。CSS 文件变得易读和理解。main-text-color比文档中的#fc0更容易理解,特别是同样的颜色出现在不同的文件中的时候
3、更方便的实现@media媒体查询
一般地,媒体查询如下所示
<style>.box{ width: 100px;height: 100px;padding: 20px;margin: 10px;background-color: red}@media screen and (max-width:600px) {.box{ width: 50px;height: 50px;padding: 10px;margin: 5px; }}</style><div></div>
但是,如果使用变量,则可以精简代码
<style>.box{ --base-size:10px;width: calc(var(--base-size) * 10);height: calc(var(--base-size) * 10);padding: calc(var(--base-size) * 2);margin: calc(var(--base-size) * 1);background-color: red;}@media screen and (max-width:600px) {.box{ --base-size:5px; }}</style><div></div>
以上是全新知識:CSS變數-variable的詳細內容。更多資訊請關注PHP中文網其他相關文章!

theroottaginanhtmldocumentis.servesasthetop-levellementThateNcapsulatesAllotherContent,確保properdocumentstrumentstrumentsureandbrowserparserparsing。

文章解釋說,HTML標籤是用於定義元素的語法標記,而元素是完整的單位,包括標籤和內容。他們一起工作以構建網頁。查拉克計數:159

本文討論了Lt; Head&gt; &&lt;身體&gt; HTML中的標籤,它們對用戶體驗的影響以及SEO的影響。正確的結構增強了網站功能和搜索引擎優化。

本文討論了HTML標籤,和和關注其語義與表現用途及其對SEO和可訪問性的影響之間的差異。

文章討論了在HTML中指定字符,重點介紹了UTF-8。主要問題:確保正確顯示文本,防止亂七八糟的字符,並增強SEO和可訪問性。

本文討論了用於構建和造型Web內容的各種HTML格式標籤,強調了它們對文本外觀的影響以及語義標籤對可訪問性和SEO的重要性。

本文討論了HTML的“ ID”和“類”屬性之間的差異,重點是它們的獨特性,目的,CSS語法和特異性。它解釋了它們的使用如何影響網頁樣式和功能,並為


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SublimeText3漢化版
中文版,非常好用

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具