」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何使用不同單位的無單位 CSS 變數?

如何使用不同單位的無單位 CSS 變數?

發佈於2024-11-18
瀏覽:946

How Can I Use Unitless CSS Variables with Different Units?

如何靈活地使用無單位CSS 變數

無單位CSS 變數提供了儲存數值的能力,這些數值可以在整個樣式表中方便使用。然而,可能會出現這樣的情況:您希望在不同的上下文中使用相同的變量,需要不同的單位,例如百分比或像素。

這種困境的一個例子是設定一個值為 10 的 CSS 變量,但是需要在一個實例中將其用作百分比,並在另一個實例中將其用作普通數字進行計算。

解決方案在於利用 calc() 函數。透過在 calc() 函數中執行變數與所需單位的簡單乘法,我們可以實現所需的靈活性。

例如,將值為10 的變數--mywidth 轉換為百分比,只需使用:

div{width:calc(var(--mywidth) * 1%);}

這將導致width 屬性被設定為10%,完全符合預期.

這種方法的多功能性擴展到各種單位,允許您在同一樣式表中所需的百分比、像素或任何其他測量單位之間無縫切換。

為了說明這一點,請考慮以下程式碼片段:

:root {
  --a:50;
}

.box {
  width:calc(var(--a) * 1%);
  border:calc(var(--a) * 0.5px) solid red;
  background:linear-gradient(calc(var(--a) * 0.8deg),blue 50% ,green 0);
  padding:20px;
  
  box-sizing:border-box;
}

在此範例中,變數 --a 用於定義各種屬性,包括寬度、邊框、背景和填充。透過利用 calc() 函數中的單位,可以根據 --a.

中儲存的值動態調整每個屬性
最新教學 更多>
  • std::string 是如何實現的以及它與 C 風格字串有何不同?
    std::string 是如何實現的以及它與 C 風格字串有何不同?
    對std::string 實現的探索對std::string 實現的探索神秘的std::string,C 標準庫的基本組件,引發了人們的關注對它的內部運作方式感到好奇。在本文中,我們深入研究其實現,揭示其複雜性,並將其與其前身、無處不在的 C 風格字串區分開來。 各種編譯器工具鏈提供對各自 std ...
    程式設計 發佈於2024-11-18
  • 為什麼 JavaScript 中 (0 < 5 < 3) 的計算結果為 true?
    為什麼 JavaScript 中 (0 < 5 < 3) 的計算結果為 true?
    JavaScript 的比較難題:破解(0 < 5 < 3) 中的真相在JavaScript 領域,出現了一個奇特的觀察結果:為什麼表達式(0 < 5 < 3) 的計算結果為true?這種神秘的行為源自於語言的求值規則,稱為操作順序。 要解開這個謎團,我們必須深入研究表達式執行的操作順序:Paren...
    程式設計 發佈於2024-11-18
  • 儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    解決PHP 中的POST 請求故障在提供的程式碼片段中:action=''而不是:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"檢查$_POST數組:表單提交後使用var_dump檢查$_POST 陣列的內容。...
    程式設計 發佈於2024-11-18
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-18
  • 如何使用 mitmproxy 修復 Windows 上的「pip install Access Denied」錯誤?
    如何使用 mitmproxy 修復 Windows 上的「pip install Access Denied」錯誤?
    使用mitmproxy 解決Windows 上的「pip install Access Denied」錯誤當嘗試使用pip 在Windows 上安裝mitmproxy 時,使用者可能會遇到儘管以管理員身分執行cmd 或PowerShell,但仍出現「存取被拒絕」錯誤。此錯誤通常在嘗試安裝 crypt...
    程式設計 發佈於2024-11-18
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1 和 $array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建...
    程式設計 發佈於2024-11-18
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-18
  • 如何從針對 Go 二進位檔案的整合測試中擷取程式碼覆蓋率?
    如何從針對 Go 二進位檔案的整合測試中擷取程式碼覆蓋率?
    從 Go 二進位檔案擷取程式碼覆蓋率執行單元測試時,擷取程式碼覆蓋率非常簡單。然而,在針對二進位檔案本身的整合測試期間收集覆蓋率指標可能具有挑戰性。有沒有辦法克服這個障礙? 整合測試覆蓋率的需求整合測試提供了比單獨的單元測試更全面的程式碼覆蓋率視圖。透過針對真實世界的輸入運行二進位文件,我們可以評估...
    程式設計 發佈於2024-11-18
  • 如何從終端機將資料庫匯入MySQL?
    如何從終端機將資料庫匯入MySQL?
    從終端導入MySQL資料庫使用終端將資料庫導入MySQL可以提供一種便捷的資料管理方式。要有效地執行此任務,請按照下列步驟操作:使用命令列,您可以存取 MySQL 提示符。這樣做的語法是:mysql -u username -p database_name輸入您的使用者名稱、密碼和目標資料庫名稱來取...
    程式設計 發佈於2024-11-18
  • 如何使用“index”函數迭代 HTML 模板中的平行數組?
    如何使用“index”函數迭代 HTML 模板中的平行數組?
    如何使用索引迭代HTML 模板中的平行數組本文解決了迭代並行數組(大小相等)的困難在HTML 模板中。具體來說,如何利用範圍區塊內的索引函數來實現此目的。 索引函數是預先定義的全域範本函數,它根據提供的索引從映射、切片或陣列中檢索項目。此函數允許在模板內的資料結構內進行複雜的導航。 在迭代並行數組的...
    程式設計 發佈於2024-11-18
  • 迭代 Python 列表時,為什麼應該避免刪除項目?
    迭代 Python 列表時,為什麼應該避免刪除項目?
    Python 列表:迭代期間刪除項目的陷阱迭代 Python 列表,同時刪除項目可能會導致意外行為。一個值得注意的例子如下:letters = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l'] for i in letters:...
    程式設計 發佈於2024-11-18
  • 如何消除 CSS 中的雙邊框:輪廓與負邊距?
    如何消除 CSS 中的雙邊框:輪廓與負邊距?
    防止 CSS 中的雙邊框許多 Web 開發人員在將元素與邊框並排設定樣式時遇到一個常見問題。由於邊框的性質,每個元素都有自己的邊框,因此元素相交處可能會出現雙邊框。這可能不雅觀並且會幹擾所需的設計。 要解決此問題,有兩種常見的解決方案:使用輪廓而不是邊框,或應用負邊距。 使用輪廓輪廓與邊框類似,但僅...
    程式設計 發佈於2024-11-18
  • 如何僅使用 CSS 將圖片嵌入 Div 元素內?
    如何僅使用 CSS 將圖片嵌入 Div 元素內?
    使用CSS 將影像整合到Div 中:有效的解決方案在Web 開發中,通常需要將影像放置在div 元素中。雖然使用背景圖像是一種常見的方法,但它限制了 div 符合圖像大小的能力。這就提出了一個問題:我們要如何使用 CSS 來建立與 HTML 結構 等效的內容? 為了實現這一點,我們利用內容屬性將圖...
    程式設計 發佈於2024-11-18
  • 如何傳遞可變數量的參數給 JavaScript 函數?
    如何傳遞可變數量的參數給 JavaScript 函數?
    向JavaScript 函數傳遞可變數量的參數JavaScript 在向函數傳遞參數方面提供了靈活性,包括從數組發送可變數量的參數的能力。 透過參數實作變數 Arity與 Python 一樣,JavaScript 有一個特殊的參數對象,它表示傳遞給函數的所有參數。該物件包含每個參數作為可索引屬性。例...
    程式設計 發佈於2024-11-18
  • 為什麼我無法使用擴充內容腳本將 CSS 注入網頁?
    為什麼我無法使用擴充內容腳本將 CSS 注入網頁?
    擴展內容腳本中的CSS 注入問題儘管在清單中定義了CSS 注入,您的CSS 文件在網頁中仍然不存在。以下是可能的原因和解決方案:原因: CSS 規則衝突樣式表已註入,但由於其他樣式覆蓋其規則而未應用。 解決方案:增加CSS特異性: 為您的 CSS 規則添加更具體的選擇器。 使用 "!im...
    程式設計 發佈於2024-11-18

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3