搜尋
首頁web前端html教學全新知識:CSS變數-variable

全新知識:CSS變數-variable

Jul 19, 2017 am 09:53 AM
cssvariable

前面的話

  一直以來,CSS中是沒有變數而言的,要使用 CSS 變量,只能藉助 SASS 或 LESS 這類預編譯器。新的草案發布之後,直接在 CSS 中定義和使用變數不再是幻想了。本文將詳細介紹CSS變數variable

 

CSS 變量,顧名思義,也就是由網頁的作者或使用者定義的實體,用來指定文件中的特定變數。

更準確的說法,應該稱為 CSS 自訂屬性 ,不過下文為了好理解都稱為 CSS 變數。

一直以來我們都知道,CSS 中是沒有變數而言的,要使用 CSS 變量,只能藉助 SASS 或 LESS 這類預編譯器。

但是新的草案發布之後,直接在CSS 中定義和使用變數已經不再是幻想了,像下面這樣,看個簡單的例子:

// 宣告一個變數:

:root{

  --bgColor:#000;

##}

   

這裡我們藉助了上篇文章 結構性偽類 中的 :root{ } 偽類,在全域 :root{ } 偽類定義了一個CSS 變量,並取名為 --bgColor 。

定義完了之後則是使用,假設我要設定一個div 的背景色為黑色:

.main{


  background :var(--bgColor);

}

   

這裡,我們在需要使用之前定義變數的地方,透過 var(定義的變數名) 來調用。

基本用法

  CSS 變數是由CSS作者定義的實體,其中包含要在整個文件中重複使用的特定值。使用自訂屬性來設定變數名,並使用特定的 var() 來存取

  相容性:行動裝置和IE瀏覽器不相容

【宣告變數】

   變數必須以

--開頭。例如--example-variable: 20px,意思是將20px賦值給--example-varibale變數

  可以將聲明變數的語句置於任何元素內,如果要設定全域變量,則可以設定為: root、body或html

:root{
  --bgColor:#000;
}
  變數宣告就像變普通的樣式宣告語句一樣,也可以使用內聯樣式


#  變量宣告語句必須包含一個元素內,而不能隨意放置

//错误
<style>
--bgColor:#000;
</style>
【使用變數】

  使用var()函數使用變量,並且可以使用在任意的地方。例如:var(--example-variable)會傳回--example-variable所對應的值

<div></div>    


  var()函數還有一個可選參數,用來設定預設值,當變數無法取得值時,則使用預設值

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


#  但是,CSS變數不能進行如下形式的組合,var(--color1)var(--color2)不被瀏覽器識別,如果分開,如var(--color1) var(-- color2),則被解析為# 333,同樣無法被瀏覽器識別
<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>


 

JS

  CSS 變數可以和JS 互相互動。要注意的是,只能使用getPropertyValue()和setProperty()方法,而不能使用style屬性

【style屬性】
<div></div>    <script>  var oBox = document.getElementById(&#39;box&#39;);
  console.log(oBox.style[&#39;--color&#39;]);    //undefined</script>

【getPropertyValue()】
<div></div>    <script>  var oBox = document.getElementById(&#39;box&#39;);
  console.log(oBox.style.getPropertyValue(&#39;--color&#39;));//&#39;lightgreen&#39;</script>

【setProperty()】
<div></div>    <script>var oBox = document.getElementById(&#39;box&#39;);var oBtn = document.getElementById(&#39;btn&#39;);
oBtn.onclick = function(){
    oBox.style.setProperty(&#39;--color&#39;,&#39;lightblue&#39;);
}</script>


 

不支援

  有一點要特別注意的是,變數不支援!important
.box{
    --color:red;
    width: 100px;
    height: 100px;
    background-color:--color !important;
}<div></div>

  chrome瀏覽器截圖如下

############################ ######用途######  1、可維護性######  在網頁中維護一個配色方案或尺寸方案,意味著一些樣式在CSS文件中多次出現,並被重複使用。當修改方案時,不論是調整某個樣式或完全修改整個方案,都會成為一個複雜的問題,而單純查找替換是遠遠不夠的,這時CSS變量就派上用場了######
: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中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
HTML文檔中的根標籤是什麼?HTML文檔中的根標籤是什麼?Apr 29, 2025 am 12:10 AM

theroottaginanhtmldocumentis.servesasthetop-levellementThateNcapsulatesAllotherContent,確保properdocumentstrumentstrumentsureandbrowserparserparsing。

HTML標籤和元素是同一件事嗎?HTML標籤和元素是同一件事嗎?Apr 28, 2025 pm 05:44 PM

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

&lt; head&gt;的意義是什麼。 &&lt;身體&gt;在html中標記?&lt; head&gt;的意義是什麼。 &&lt;身體&gt;在html中標記?Apr 28, 2025 pm 05:43 PM

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

&lt; strong&gt;,lt; b&gt;有什麼區別標籤和lt; em&gt;,&lt; i&gt;標籤?&lt; strong&gt;,lt; b&gt;有什麼區別標籤和lt; em&gt;,&lt; i&gt;標籤?Apr 28, 2025 pm 05:42 PM

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

請說明如何指示HTML中文檔使用的字符集?請說明如何指示HTML中文檔使用的字符集?Apr 28, 2025 pm 05:41 PM

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

HTML中的各種格式標籤是什麼?HTML中的各種格式標籤是什麼?Apr 28, 2025 pm 05:39 PM

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

HTML元素的' ID”屬性與'類”屬性之間有什麼區別?HTML元素的' ID”屬性與'類”屬性之間有什麼區別?Apr 28, 2025 pm 05:39 PM

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

HTML中的'類”屬性是什麼?HTML中的'類”屬性是什麼?Apr 28, 2025 pm 05:37 PM

本文解釋了HTML“類”屬性在分組樣式和JavaScript操縱元素中的作用,將其與唯一的“ ID”屬性進行對比。

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脫衣器

Video Face Swap

Video Face Swap

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

熱工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SecLists

SecLists

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

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具