溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

微信小程序中如何使用自定義字體

發(fā)布時(shí)間:2022-02-21 14:42:41 來源:億速云 閱讀:249 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹了微信小程序中如何使用自定義字體的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇微信小程序中如何使用自定義字體文章都會(huì)有所收獲,下面我們一起來看看吧。

    技術(shù)難點(diǎn)

    1. 微信限制

    大家開發(fā)過微信小程序的應(yīng)該都知道,微信平臺(tái)對小程序的體積大小有限制:

    • 整個(gè)小程序所有分包大小不超過 20M

    • 單個(gè)分包/主包大小不能超過 2M

    出于這個(gè)限制,字體肯定沒有辦法放到本地資源中了,那就只有一條出路,將資源放到第三方cdn資源中。但是使用cdn資源有一點(diǎn)需要注意:需要配置合法域名。

    微信小程序中如何使用自定義字體

    2. 機(jī)型兼容

    經(jīng)過初步測試,發(fā)現(xiàn)使用自定義字體在不同的機(jī)型上的兼容性有所出入,尤其是安卓手機(jī)。經(jīng)過一定數(shù)量的測試得出一個(gè)粗淺的結(jié)論:ttf字體在iOS手機(jī)上兼容性比較好,在安卓機(jī)上會(huì)出現(xiàn)特殊機(jī)型失效的問題。

    說到這里,我就忍不住吐槽兩句,這段時(shí)間進(jìn)行機(jī)型適配的時(shí)候,華為鴻蒙和蘋果xs真的是折磨的我死去活來的,經(jīng)常出現(xiàn)一些跟大眾機(jī)型與眾不同的問題。

    經(jīng)過一番查找,發(fā)現(xiàn)了兩種解決方案:

    • 使用 css 樣式,引入多種字體類型,包含.ttf 和 .woff 類型

    • 使用微信官方api —— wx.loadFontFace

    經(jīng)過慎重考慮,我們最終采用了第二種方案。

    文檔說明

    字體文件返回的 contet-type 參考 font,格式不正確時(shí)會(huì)解析失敗。

    字體鏈接必須是https(ios不支持http)

    字體鏈接必須是同源下的,或開啟了cors支持,小程序的域名是servicewechat.com

    工具里提示 Faild to load font可以忽略

    '2.10.0' 以前僅在調(diào)用頁面生效。

    重要的事情再三強(qiáng)調(diào):字體鏈接必須是同源下的,或開啟了cors支持。

    我當(dāng)時(shí)就是由于使用第三方cdn資源,但是沒有配置cors支持,導(dǎo)致安卓手機(jī)上一直不生效。而且比較難排查的另一個(gè)原因是,模擬器上和蘋果手機(jī)上沒有配置cors支持,但是依然生效,很奇怪。

    體驗(yàn)優(yōu)化

    雖然 wx.loadFontFace 是官方提供的api,但是有個(gè)體驗(yàn)問題很是折磨:wx.loadFontFace 每次進(jìn)入頁面 都會(huì)重新下載,而且會(huì)出現(xiàn)字體閃動(dòng)。

    字體閃動(dòng)的問題相對來說比較容易體驗(yàn),在字體加載完成之前,添加了loading效果,而且在進(jìn)入入口的時(shí)候第一時(shí)間就開始加載字體。

    每次都加載的問題,通過惰性模式緩解了一下,但是沒有完全解決(由于cdn資源會(huì)進(jìn)行緩存,所以考慮通過判斷緩存資源是否存在來判斷是否需要加載字體,但是很遺憾,還沒有實(shí)現(xiàn)),直接上一下現(xiàn)在的搓代碼吧。

        let loadStatus = false;
        if (!loadStatus) {
            ```
        wx.loadFontFace({
          family: '...',
          source: 'url("...")',
          success() {
              loadStatus = ture;
          }
        });

    附微信小程序設(shè)置全局字體

    微信小程序設(shè)置全局css,需要在app.wxss文件中設(shè)置page的樣式

    page {
      font-family:"PingFangSC-Thin";
       font-size:32rpx;          /*微信小程序中,使用rpx做單位*/
    }

    關(guān)于“微信小程序中如何使用自定義字體”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“微信小程序中如何使用自定義字體”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

    向AI問一下細(xì)節(jié)

    免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

    AI