微信小程序中使用自定義字體的實(shí)現(xiàn)與體驗(yàn)優(yōu)化
前言
前段時(shí)間,甲方爸爸提出一個(gè)比較個(gè)性化的需要:要在他們的小程序中使用他們購買過版權(quán)的特殊字體。好家伙,我瞬間萬馬奔騰,我三十米的大刀呢?奈何甲方爸爸就是上帝,甲方爸爸想到的我們要盡量是實(shí)現(xiàn),甲方爸爸沒有想到的我們要提前實(shí)現(xiàn)。
怎么實(shí)現(xiàn)呢?
開擼之前,先研究一下,探索一下技術(shù)方案。
技術(shù)難點(diǎn)
1. 微信限制
大家開發(fā)過微信小程序的應(yīng)該都知道,微信平臺(tái)對(duì)小程序的體積大小有限制:
整個(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)的問題相對(duì)來說比較容易體驗(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做單位*/ }
結(jié)尾
到此這篇關(guān)于微信小程序中使用自定義字體的文章就介紹到這了,更多相關(guān)微信小程序使用自定義字體內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript中改變this指向的三種方式總結(jié)
this?指向的值是可以通過手動(dòng)方式去改變的,比如call、bind、apply方法,本文主要為大家介紹了這三種方式的具體實(shí)現(xiàn)步驟,需要的可以參考下2023-12-12Bootstrap treeview實(shí)現(xiàn)動(dòng)態(tài)加載數(shù)據(jù)并添加快捷搜索功能
本文實(shí)現(xiàn)了運(yùn)用bootstrap treeview實(shí)現(xiàn)動(dòng)態(tài)加載數(shù)據(jù),并且添加快捷搜索功能,需要的朋友參考下2018-01-01微信內(nèi)置瀏覽器WeixinJSBridge的使用技巧(隱藏右上角按鈕,獲取用戶網(wǎng)絡(luò)狀態(tài),支付等)
這篇文章主要介紹了微信內(nèi)置瀏覽器WeixinJSBridge的使用技巧,隱藏右上角按鈕,獲取用戶網(wǎng)絡(luò)狀態(tài),支付,隱藏下方工具欄等,需要的朋友可以參考下2024-02-02js實(shí)現(xiàn)百度地圖定位于地址逆解析,顯示自己當(dāng)前的地理位置
本文分享了基于javascript實(shí)現(xiàn)的百度地圖定位于地址逆解析,顯示自己當(dāng)前的地理位置的實(shí)例代碼,有興趣的朋友可以看下2016-12-12JavaScrpt中如何使用 cookie 設(shè)置查看與刪除功能
這篇文章主要介紹了JavaScrpt中使用 cookie 設(shè)置查看與刪除功能的方法,文中通過實(shí)例代碼給大家介紹了js cookie常用的3個(gè)預(yù)設(shè)函數(shù)庫,需要的朋友可以參考下2017-07-07創(chuàng)建一個(gè)復(fù)制UBB軟件信息的鏈接或按鈕的js代碼
2008-01-01用js統(tǒng)計(jì)用戶下載網(wǎng)頁所需時(shí)間的腳本
下面的方法是個(gè)不錯(cuò)的思路,建議對(duì)于js感興趣的朋友,推薦看2008-10-10