Add custom fonts to your React Native application 2024 guide
This is a concise guide — on how to add a custom font to your react-native app (ReactNative CLI). We will add a few popular fonts. One of them will be the Roboto font for your React Native App.
2 min readMar 15, 2024
Let’s Start:
- Download your favorite font from the Google Fonts Web Page or any other sources
- Copy the
.ttf
files to the folder, dedicated specifically to assets (in my case it isassets/fonts
data:image/s3,"s3://crabby-images/3bbce/3bbce8940735e969678d0245dee741e90b4e3312" alt="Screenshot from my test project folder’s structure after adding custom fonts"
3. Create a file called `react-native.config.js` in the project’s root folder:
module.exports = {
// ...other config
// add the line below with path to your fonts folder
assets: ['./assets/fonts']
};
4. For react-native ≥ 0.69 run the command:
npx react-native-asset
data:image/s3,"s3://crabby-images/05501/05501a6e57feecb5c56958bfc08dfb524d6a1a0f" alt=""
data:image/s3,"s3://crabby-images/d1493/d14936a0faa2a5373838e389ae990058e9ad3367" alt="Screenshot of the files changed in ios folder after running command npx react-native-asset"
data:image/s3,"s3://crabby-images/8adbc/8adbc9752388837f3fe37080979480826a652b5e" alt="Screenshot of the files changed in android folder after running command npx react-native-asset"
5. Configure your <Text />
component styles:
const styles = StyleSheet.create({
text1: {
fontFamily: 'NovaSquare-Regular',
fontSize: 24,
},
text2: {
fontFamily: 'Roboto-BlackItalic',
fontSize: 24,
},
text3: {
fontFamily: 'NovaSquare-Regular',
fontSize: 24
},
});
Enjoy your new custom fonts.
data:image/s3,"s3://crabby-images/37a3e/37a3e4f6396cefe3cf4b0c9e7cf3ed3f8cb429ff" alt="Screenshot of the final result"
Some troubleshooting:
1. If you have problems defining fontFamily
name. Take a look at the PostScript Name in the FontBook app on MacBook.
data:image/s3,"s3://crabby-images/22263/22263a9ab6e868b08ef4ffc1dd329fbdc9fe1b32" alt=""
2. Don’t forget to rebuild your app after you have added a new font.
data:image/s3,"s3://crabby-images/98de9/98de92053aec1c2636fa530891172dd424936f71" alt=""