首頁 web前端 css教學 使用CSS自定義屬性在黑模式下調整可變字體權重

使用CSS自定義屬性在黑模式下調整可變字體權重

Apr 01, 2025 am 03:52 AM

暗模式對文本可讀性的影響:使用可變字體的CSS解決方案

黑暗模式雖然美學上令人愉悅,但通常會帶來一個挑戰:在黑暗的背景下,文本看起來更重。本文使用CSS自定義屬性和可變字體探討解決方案來解決此問題,從而確保跨光和黑暗模式的文本外觀一致。

使用CSS自定義屬性在黑模式下調整可變字體權重

問題不是幻想。較輕的角色在深色背景上確實看起來更大膽。當比較光和暗模式文本時,這很容易觀察到,並且在倒轉顏色時變得更加清晰。

使用可變字體的解決方案

可變字體提供了強大的解決方案。理想的效果涉及在黑暗模式下巧妙地變薄的文本,而不會改變字符寬度。我們可以通過幾種策略來實現這一目標:

  1. 手動調整font-weight這涉及在黑模式媒體查詢中直接修改font-weight值。功能性雖然具有許多元素,但它變得繁瑣。

  2. font-weight乘數:一種更優雅的方法使用CSS自定義屬性( --font-weight-multiplier )來控制重量調整。此乘數在暗模式下修改了每個元素的默認font-weight 。例如,設置--font-weight-multiplier為0.85可將重量降低15%。

  3. 通用選擇器和乘數:此高級技術利用CSS變量範圍和通用選擇器( * )在全球應用乘數計算。這簡化了CSS,但需要仔細考慮以避免對特定元素的意外影響。

  4. font-variation-settings和軸操縱:某些可變字體提供諸如“ grad”(級)或“ drkm”(暗模式)之類的軸,它們直接控制明顯的重量而不會影響字符寬度。 Roboto Flex利用“ Grad”,而Dalton Maag的Darkmode字體具有“ Drkm”軸。

策略1: font-weight操縱

最簡單的方法是在暗模式媒體查詢中手動調整每個元素的font-weight 。但是,隨著元素數量的增加,這將變得易於管理。

 / *默認(燈模式)CSS */
身體{字體權重:400; }
強{字體重量:700; }

/ *黑模式CSS */
@Media(prefers-color-scheme:dark){
  身體{字體權重:350; }
  強{字體重量:600; }
}
登入後複製

策略2:具有自定義屬性的font-weight乘數

使用自定義屬性( --font-weight-multiplier )提供了更可維護的解決方案。

 / *暗模式特定的自定義屬性 */
@Media(prefers-color-scheme:dark){
  :root { -  -font-weight-Multiplier:.85; }
}

/ *默認的CSS樣式... */
Body {font-jight:calc(400 * var( -  font-weight-multiplier,1)); }
strong {font-jight:calc(700 * var( -  font-weight-multiplier,1)); }
登入後複製

策略3:通用選擇器和乘數

這種方法一次將乘數應用於所有元素。

 / *默認自定義屬性 */
:root { -  -font-jight:400; - 聯合體重 - 武力:1; }
強{ -   - 五大:700; }

/ *暗模式特定的自定義屬性 */
@Media(prefers-color-scheme:dark){
  :root { -  -font-weight-Multiplier:.85; }
}

/ *應用自定義屬性... */
* {font-權重:calc(var( -  font-pronger,400) * var( -  font-weight-multiplier,1)); }
登入後複製

策略4:用font-variation-settings軸操縱

具有“畢業”或“ DRKM”軸的字體可直接控制重量。

 / *對於Roboto Flex(“畢業”軸) */
:root {-grad:0; }
@Media(prefers-color-scheme:dark){:root { -  grad:-.75; }}}
身體{font-variation-settings:“ grad” var( -  grad,0); }
登入後複製

其他考慮因素

  • 高分辨率屏幕:對視網膜顯示器的效果不太明顯。相應地調整乘數。
  • 混合字體:仔細考慮對具有不同軸或不可變化字體的字體的影響。
  • 信件間隔:降低字體重量可以縮小字符。根據需要調整字母間隔。

通過利用這些技術,開發人員可以確保跨光和深色模式的一致且清晰的文本,從而增強整體用戶體驗。可以提供展示這些策略的演示[鏈接到演示]。

以上是使用CSS自定義屬性在黑模式下調整可變字體權重的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱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

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

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1657
14
CakePHP 教程
1415
52
Laravel 教程
1309
25
PHP教程
1257
29
C# 教程
1230
24
Google字體可變字體 Google字體可變字體 Apr 09, 2025 am 10:42 AM

我看到Google字體推出了新設計(Tweet)。與上一次大型重新設計相比,這感覺更加迭代。我幾乎無法分辨出區別

如何使用HTML,CSS和JavaScript創建動畫倒計時計時器 如何使用HTML,CSS和JavaScript創建動畫倒計時計時器 Apr 11, 2025 am 11:29 AM

您是否曾經在項目上需要一個倒計時計時器?對於這樣的東西,可以自然訪問插件,但實際上更多

HTML數據屬性指南 HTML數據屬性指南 Apr 11, 2025 am 11:50 AM

您想了解的有關HTML,CSS和JavaScript中數據屬性的所有信息。

使Sass更快的概念證明 使Sass更快的概念證明 Apr 16, 2025 am 10:38 AM

在一個新項目開始時,Sass彙編發生在眼睛的眨眼中。感覺很棒,尤其是當它與browsersync配對時,它重新加載

我們如何創建一個在SVG中生成格子呢模式的靜態站點 我們如何創建一個在SVG中生成格子呢模式的靜態站點 Apr 09, 2025 am 11:29 AM

格子呢是一塊圖案布,通常與蘇格蘭有關,尤其是他們時尚的蘇格蘭語。在Tar​​tanify.com上,我們收集了5,000多個格子呢

如何在WordPress主題中構建VUE組件 如何在WordPress主題中構建VUE組件 Apr 11, 2025 am 11:03 AM

內聯式模板指令使我們能夠將豐富的VUE組件構建為對現有WordPress標記的逐步增強。

php是A-OK用於模板 php是A-OK用於模板 Apr 11, 2025 am 11:04 AM

PHP模板通常會因促進Subpar代碼而變得不良說唱,但這並不是這樣的情況。讓我們看一下PHP項目如何執行基本的

編程SASS創建可訪問的顏色組合 編程SASS創建可訪問的顏色組合 Apr 09, 2025 am 11:30 AM

我們一直在尋求使網絡更容易訪問。顏色對比只是數學,因此Sass可以幫助涵蓋設計師可能錯過的邊緣案例。

See all articles