如何在React項(xiàng)目中引入字體文件并使用詳解
前言
在做React項(xiàng)目的時(shí)候,發(fā)現(xiàn)UI設(shè)計(jì)給出的設(shè)計(jì)稿里,某些文字所用的字體,系統(tǒng)默認(rèn)不支持。比如設(shè)計(jì)需要的這個(gè)字體:EmerlandRegular,即使在css里將文字字體設(shè)置為他們,實(shí)際效果也顯示不出來(lái)。
<Typography
style={{
fontSize:'22px',
fontFamily:'EmerlandRegular',
textAlign:'center',
color:'#3A3A3A',
marginTop: '10px',
}}
>
This teacher is good
</Typography>期待效果:

實(shí)際效果:

實(shí)際上是因?yàn)檫@個(gè)字體不在系統(tǒng)的預(yù)置字體庫(kù)里,所以找不到,就顯示了默認(rèn)的字體樣式。要想達(dá)到期待的字體效果,需要把字體文件引入項(xiàng)目才行。
下面講下如何引入字體文件并使用
一、下載字體包
這一步就不多說(shuō)了,字體包從網(wǎng)上找,或者讓UI設(shè)計(jì)師提供給你。
下載好的字體包一般是個(gè)壓縮包,打開(kāi)后有多個(gè)字體文件,如圖:

這么多字體文件,哪個(gè)是我們需要的呢,看文件名,分為兩種,帶italic的和不帶的,顯然帶italic的就是斜體字文件,而不帶italic的就是我們想要的正常字體文件。但是后綴又有otf, ttf, woff幾種,選哪個(gè)呢,其實(shí)這幾種都是文件格式有區(qū)別,顯示出來(lái)一般是沒(méi)什么區(qū)別的,就跟word文檔也可以存為好幾種文檔后綴一樣,可以隨意選一種先看看。這里我們使用 Emerland.ttf文件。
二、將字體文件放到項(xiàng)目里
1.在項(xiàng)目public文件夾下新建一個(gè)fonts文件夾,用于存放字體,然后將字體文件復(fù)制到這個(gè)文件夾下。
2.在public下新建一個(gè)font.css,文件內(nèi)容里加上對(duì)新引入的字體的定義:
@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" >
添加位置如圖:

這樣,就成功的把字體文件引入項(xiàng)目了。
三、使用新字體
因?yàn)槲覀冊(cè)趂ont.css里給新字體起的名叫EmerlandRegular,所以在使用的時(shí)候,就像以前那樣,給需要的文字設(shè)置fontFamily為"EmerlandRegular"即可。
fontFamily:'EmerlandRegular'
運(yùn)行即可看到字體效果已經(jīng)成功顯示了。

總結(jié)
到此這篇關(guān)于如何在React項(xiàng)目中引入字體文件并使用的文章就介紹到這了,更多相關(guān)React項(xiàng)目引入字體文件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用Axios在React中請(qǐng)求數(shù)據(jù)的方法詳解
這篇文章主要給大家介紹了初學(xué)React,如何規(guī)范的在react中請(qǐng)求數(shù)據(jù),主要介紹了使用axios進(jìn)行簡(jiǎn)單的數(shù)據(jù)獲取,加入狀態(tài)變量,優(yōu)化交互體驗(yàn),自定義hook進(jìn)行數(shù)據(jù)獲取和使用useReducer改造請(qǐng)求,本文主要適合于剛接觸React的初學(xué)者以及不知道如何規(guī)范的在React中獲取數(shù)據(jù)的人2023-09-09
React使用ref進(jìn)行訪問(wèn)DOM元素或組件
在 React 里,ref 就像是一個(gè)神奇的小助手,能讓你直接去訪問(wèn) DOM 元素或者組件實(shí)例,下面就跟隨小編一起來(lái)學(xué)習(xí)一下具體的使用方法吧2025-03-03
詳解使用WebPack搭建React開(kāi)發(fā)環(huán)境
這篇文章主要介紹了詳解使用WebPack搭建React開(kāi)發(fā)環(huán)境,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
react實(shí)現(xiàn)Radio組件的示例代碼
這篇文章主要介紹了react實(shí)現(xiàn)Radio組件的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
解決React報(bào)錯(cuò)Cannot?find?namespace?context
這篇文章主要為大家介紹了React報(bào)錯(cuò)Cannot?find?namespace?context分析解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
ReactNative集成個(gè)推消息推送過(guò)程詳解
這篇文章主要為大家介紹了ReactNative集成個(gè)推消息推送過(guò)程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
React從react-router路由上做登陸驗(yàn)證控制的方法
本篇文章主要介紹了React從react-router路由上做登陸驗(yàn)證控制的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-05-05
webpack構(gòu)建react多頁(yè)面應(yīng)用詳解
這篇文章主要介紹了webpack構(gòu)建react多頁(yè)面應(yīng)用詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09

