如何在React項目中引入字體文件并使用詳解
前言
在做React項目的時候,發(fā)現(xiàn)UI設(shè)計給出的設(shè)計稿里,某些文字所用的字體,系統(tǒng)默認(rèn)不支持。比如設(shè)計需要的這個字體:EmerlandRegular,即使在css里將文字字體設(shè)置為他們,實際效果也顯示不出來。
<Typography style={{ fontSize:'22px', fontFamily:'EmerlandRegular', textAlign:'center', color:'#3A3A3A', marginTop: '10px', }} > This teacher is good </Typography>
期待效果:
實際效果:
實際上是因為這個字體不在系統(tǒng)的預(yù)置字體庫里,所以找不到,就顯示了默認(rèn)的字體樣式。要想達(dá)到期待的字體效果,需要把字體文件引入項目才行。
下面講下如何引入字體文件并使用
一、下載字體包
這一步就不多說了,字體包從網(wǎng)上找,或者讓UI設(shè)計師提供給你。
下載好的字體包一般是個壓縮包,打開后有多個字體文件,如圖:
這么多字體文件,哪個是我們需要的呢,看文件名,分為兩種,帶italic的和不帶的,顯然帶italic的就是斜體字文件,而不帶italic的就是我們想要的正常字體文件。但是后綴又有otf, ttf, woff幾種,選哪個呢,其實這幾種都是文件格式有區(qū)別,顯示出來一般是沒什么區(qū)別的,就跟word文檔也可以存為好幾種文檔后綴一樣,可以隨意選一種先看看。這里我們使用 Emerland.ttf文件。
二、將字體文件放到項目里
1.在項目public文件夾下新建一個fonts文件夾,用于存放字體,然后將字體文件復(fù)制到這個文件夾下。
2.在public下新建一個font.css,文件內(nèi)容里加上對新引入的字體的定義:
@font-face { font-family: EmerlandRegular; src: url('./fonts/Emerland.ttf'); }
這就聲明了一種新字體,字體名叫EmerlandRegular,字體文件的路徑就是src指定的路徑。
上面這兩步如圖:
3.修改index.html文件,添加這一行:
<link rel="stylesheet" href="%PUBLIC_URL%/font.css" rel="external nofollow" >
添加位置如圖:
這樣,就成功的把字體文件引入項目了。
三、使用新字體
因為我們在font.css里給新字體起的名叫EmerlandRegular,所以在使用的時候,就像以前那樣,給需要的文字設(shè)置fontFamily為"EmerlandRegular"即可。
fontFamily:'EmerlandRegular'
運行即可看到字體效果已經(jīng)成功顯示了。
總結(jié)
到此這篇關(guān)于如何在React項目中引入字體文件并使用的文章就介紹到這了,更多相關(guān)React項目引入字體文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
react-native-video實現(xiàn)視頻全屏播放的方法
這篇文章主要介紹了react-native-video實現(xiàn)視頻全屏播放的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03react使用axios進(jìn)行api網(wǎng)絡(luò)請求的封裝方法詳解
這篇文章主要為大家詳細(xì)介紹了react使用axios進(jìn)行api網(wǎng)絡(luò)請求的封裝方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03React中完整實例講解Recoil狀態(tài)管理庫的使用
這篇文章主要介紹了React中Recoil狀態(tài)管理庫的使用,Recoil的產(chǎn)生源于Facebook內(nèi)部一個可視化數(shù)據(jù)分析相關(guān)的應(yīng)用,在使用React的實現(xiàn)的過程中,因為現(xiàn)有狀態(tài)管理工具不能很好的滿足應(yīng)用的需求,因此催生出了Recoil,對Recoil感興趣可以參考下文2023-05-05淺談React-router v6 實現(xiàn)登錄驗證流程
本文主要介紹了React-router v6 實現(xiàn)登錄驗證流程,主要介紹了公共頁面、受保護(hù)頁面和登錄頁面,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05