首頁 >web前端 >css教學 >如何使用 @font-face 檢測字體何時加載以避免 FOUC?

如何使用 @font-face 檢測字體何時加載以避免 FOUC?

Patricia Arquette
Patricia Arquette原創
2024-12-18 05:22:10758瀏覽

How Can I Detect When a Font Has Loaded Using @font-face to Avoid 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中文網其他相關文章!

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