如何使用 @font-face 檢測字體何時加載以避免 FOUC?
使用@font-face 偵測字體的載入狀態
Web 開發人員經常會遇到圖示或字體顯示為佔位符字符,直到字體檔案完全加載。這可能會分散用戶的注意力或破壞用戶體驗。要解決這個問題,了解字體何時加載至關重要。
字體載入偵測問題
在問題中提到的具體場景中,Font-Awesome由於字體檔案載入延遲,圖示最初顯示為 。目標是在字體加載之前隱藏這些圖標,增強網站的視覺外觀和功能。
字體載入偵測解決方案
在等待整個過程時頁面載入可能不可行,有一些方法可以確定字體是否已被專門載入。一種有效的方法是比較以兩種不同字體呈現的字串的寬度。
jQuery-FontSpy.js 外掛程式
為了簡化此過程,jQuery-FontSpy .js 外掛程式已開發完畢,可在GitHub (https://github.com /patrickmarabeas/jQuery-FontSpy.js) 上取得。該插件提供了一種直觀的方法來檢測字體加載並相應地應用樣式。
使用 jQuery-FontSpy.js
要使用該插件,請將插件的 JavaScript 檔案包含在您的專案並在目標元素上初始化它。您可以根據字體載入狀態指定要新增或刪除的自訂類別。例如:
<span class="bannerTextChecked">FontAwesome Icon</span>
$(document).ready(function() { $('.bannerTextChecked').fontSpy({ onLoad: 'hideMe', onFail: 'fontFail anotherClass' }); });
用於 FOUC 刪除的 CSS
要完全刪除無樣式內容的 Flash (FOUC),請套用適當的CSS規則:
.hideMe { visibility: hidden !important; } .fontFail { visibility: visible !important; /* fallback font */ /* apply necessary styling to avoid layout issues with the fallback font */ }
結論
透過利用字體載入偵測技術,您可以透過確保字體僅在完全載入時顯示來增強使用者體驗。 jQuery-FontSpy.js 讓這個過程變得毫不費力,讓您能夠根據特定字體的載入狀態添加樣式。
以上是如何使用 @font-face 檢測字體何時加載以避免 FOUC?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

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

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

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

在元素個數不固定的情況下如何通過CSS選擇第一個指定類名的子元素在處理HTML結構時,常常會遇到元素個數不�...

關於Flex佈局中紫色斜線區域的疑問在使用Flex佈局時,你可能會遇到一些令人困惑的現象,比如在開發者工具(d...
