欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在React Native中添加自定義字體的方法詳解

 更新時間:2024年02月23日 09:15:32   作者:王大冶  
在這篇指南中,我們將探索使用 Google Fonts 在 React Native 應(yīng)用中添加自定義字體的方法,字體是優(yōu)秀用戶體驗的基石,使用定制字體可以為你的應(yīng)用程序提供獨特的身份,需要的朋友可以參考下

字體是優(yōu)秀用戶體驗的基石。使用定制字體可以為你的應(yīng)用程序提供獨特的身份,幫助你的項目在競爭激烈的市場中脫穎而出。

在這篇指南中,我們將探索使用 Google Fonts 在 React Native 應(yīng)用中添加自定義字體的方法。要跟上進度,你應(yīng)該熟悉 React Native 或 Expo SDK 的基礎(chǔ)知識,包括 JSX、組件(類和函數(shù)式)和樣式。

向 React Native CLI 項目添加自定義字體

對于我們的項目,我們將研究如何通過構(gòu)建使用Google字體的基礎(chǔ)應(yīng)用程序,將自定義字體添加到React Native CLI項目中。Google字體是一個免費的開源字體庫,可在設(shè)計網(wǎng)頁和移動應(yīng)用程序時使用。

要啟動React Native CLI項目,請在終端中運行以下命令:

npx react-native@latest init CustomFontCLI

CustomFontCLI 是我們的項目文件夾的名稱。一旦項目成功安裝,你將會看到下面的圖片:

在你喜歡的IDE中打開你的項目以開始。在這個教程中,我們將使用VS Code。

一旦項目已經(jīng)啟動,我們將繼續(xù)獲取我們想要使用的字體。我們將討論如何導(dǎo)入它們并在我們的項目中使用它們。

下載并將Google字體集成到我們的項目中

在這個項目中,我們將使用兩種字體:QuickSandRaleway,演示自定義字體的集成,你可以在Google字體上找到它們。

在 Google Fonts 中找到你想要的字體,選擇你想要的樣式(例如,Light 300, Regular 400 等),并使用“下載全部”按鈕下載整個字體文件夾:

該文件夾將以ZIP文件的形式下載,其中包含一個字體文件夾。在該文件夾內(nèi),有一個靜態(tài)文件夾,所有的TTF文件都在其中。復(fù)制并保留這些TTF文件。

在下一部分,我們將會講解如何將這些字體的TTF文件集成到我們的React Native CLI項目中。

將Google字體集成到項目中

在你的項目根目錄中創(chuàng)建一個名為 assets 的文件夾,并在其中創(chuàng)建一個名為 fonts 的子文件夾。然后,將你之前從靜態(tài)文件夾中復(fù)制的所有TTF文件粘貼到你的項目的 fonts 文件夾中:

接下來,在根目錄中創(chuàng)建一個 react-native.config.js 文件,并將下面的代碼粘貼到其中:

將字體鏈接到要在項目文件中使用

我們已經(jīng)成功地將字體文件集成到我們的項目中。現(xiàn)在我們需要鏈接它們,這樣我們就能在項目內(nèi)的任何文件中使用它們。要做到這一點,運行以下命令:

npx react-native-asset

一旦資源成功鏈接,你應(yīng)該會在終端看到以下消息:

然后,在你的 App.js 文件中,粘貼以下代碼:

import {StyleSheet, Text, View} from 'react-native';
import React from 'react';
const App = () => {
  return (
    <View style={styles.container}>
      <Text style={styles.quicksandRegular}>
        This text uses a quick sand font
      </Text>
      <Text style={styles.quicksandLight}>
        This text uses a quick sand light font
      </Text>
      <Text style={styles.ralewayThin}>
        This text uses a thin italic raleway font
      </Text>
      <Text style={styles.ralewayItalic}>
        This text uses a thin italic raleway font
      </Text>
    </View>
  );
};
export default App;
const styles = StyleSheet.create({
  container: {
    backgroundColor: 'lavender',
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
  },
  quicksandLight: {
    fontFamily: 'Quicksand-Light',
    fontSize: 20,
  },
  quicksandRegular: {
    fontFamily: 'Quicksand-Regular',
    fontSize: 20,
  },
  ralewayItalic: {
    fontFamily: 'Raleway-Italic',
    fontSize: 20,
  },
  ralewayThin: {
    fontFamily: 'Raleway-ThinItalic',
    fontSize: 20,
  },
});

這是一個基本的 App.js 文件,其中四個文本被不同的 RalewayQuicksand 字體樣式所樣式化。本質(zhì)上,我們正在渲染 JSX 與四個文本以顯示在屏幕上,并使用 React Native 的 StyleSheet API 為每個 Text 組件附加不同的 fontFamily 樣式。

讓我們看看輸出:

在Expo中使用自定義字體的React Native

在這一部分,我們將學(xué)習(xí)如何在Expo中使用自定義字體。Expo 支持兩種字體格式,OTFTTF,這兩種格式在 iOS、Android 和 Web上都能穩(wěn)定運行。如果你的字體是其他格式,你將需要進行高級配置。

首先,通過運行此命令創(chuàng)建一個新的Expo項目:

npx create-expo-app my-app

一旦項目成功安裝,通過運行 npm run start 啟動開發(fā)服務(wù)器,并選擇iOS 或 Android 選項來打開你的項目。

當(dāng)你的模擬器完成項目加載后,你應(yīng)該會看到這個:

使用Google字體

因為我們將 Raleway 和 Quicksand 字體添加為我們的自定義字體,我們將安裝這兩個包:

@expo-google-fonts/raleway
@expo-google-fonts/quicksand

如果你有其他想要使用的Google字體,你可以在這里查看Expo支持的可用字體。

在Expo項目中集成自定義的Google字體

在你的 App.js 文件中,粘貼以下代碼塊:

import { Raleway_200ExtraLight } from "@expo-google-fonts/raleway";
import { Quicksand_300Light } from "@expo-google-fonts/quicksand";
import { useFonts } from "expo-font";
import { StatusBar } from "expo-status-bar";
import { StyleSheet, Text, View } from "react-native";
export default function App() {
  const [fontsLoaded] = useFonts({
    Raleway_200ExtraLight,
    Quicksand_300Light,
  });
  if (!fontsLoaded) {
    return <Text>Loading...</Text>;
  }
  return (
    <View style={styles.container}>
      <Text>This text has default style</Text>
      <Text style={styles.raleway}>This text uses Raleway Font</Text>
      <Text style={styles.quicksand}>This text uses QuickSand Font</Text>
      <StatusBar style="auto" />
    </View>
  );
}
const styles = StyleSheet.create({
  container: {
    flex: 1,
    backgroundColor: "#fff",
    alignItems: "center",
    justifyContent: "center",
  },
  raleway: {
    fontSize: 20,
    fontFamily: "Raleway_200ExtraLight",
  },
  quicksand: {
    fontSize: 20,
    fontFamily: "Quicksand_300Light",
  },
});

在這里,我們從各自的包中導(dǎo)入了 Raleway_200ExtraLightQuicksand_300Light 。 useFonts 鉤子用于異步加載這些自定義字體。 useFonts 鉤子的結(jié)果是一個布爾值數(shù)組,我們使用 const [fontsLoaded] 語法進行解構(gòu),以訪問它返回的布爾值。

如果字體成功加載,結(jié)果將是 [true, null] ,這意味著 fontsLoaded 是真的。如果不成功,它將返回 [false, null] 。如果字體還未加載,我們將返回一個 Loading 文本。

如果傳遞給 useFont 鉤子的字體(如上面的代碼塊所示)已經(jīng)加載,那么就渲染應(yīng)用程序,我們指定的字體應(yīng)該會被使用。

在我們的模擬器中看看這是什么樣子:

使用自定義字體

假設(shè)你正在構(gòu)建一個個人的 React Native 項目,并且你得到了一些自定義字體,這些字體并不在 Expo 支持的 Google 字體庫中。

首先,你需要下載 font 文件到你的項目中,并安裝 expo-font 包。對于這個教程,我從 FontSquirrel 下載了 Source Code Pro 作為我的自定義字體。

創(chuàng)建一個名為 assets 的文件夾,并在其中創(chuàng)建一個 fonts 文件夾,就像你使用React Native CLI所做的那樣。然后,從 fonts 文件夾獲取并復(fù)制字體文件到你的機器和你的項目中,如下所示:

在你的 App.js 文件中,粘貼以下代碼:

import { useFonts } from "expo-font";
import { StatusBar } from "expo-status-bar";
import { StyleSheet, Text, View } from "react-native";
export default function App() {
  const [fontsLoaded] = useFonts({
    "SourceCodePro-ExtraLight": require("./assets/fonts/SourceCodePro-ExtraLight.otf"),
    "SourceCodePro-LightIt": require("./assets/fonts/SourceCodePro-LightIt.otf"),
  });
  if (!fontsLoaded) {
    return <Text>Loading...</Text>;
  }
  return (
    <View style={styles.container}>
      <Text style={styles.default}>This text has default style</Text>
      <Text style={styles.sourcepro}>This text uses Source Pro Font</Text>
      <Text style={styles.sourceprolight}>This text uses Source Pro Font</Text>
      <StatusBar style="auto" />
    </View>
  );
}
const styles = StyleSheet.create({
  container: {
    flex: 1,
    backgroundColor: "#fff",
    alignItems: "center",
    justifyContent: "center",
  },
  default: {
    fontSize: 20,
  },
  sourcepro: {
    fontSize: 20,
    fontFamily: "SourceCodePro-ExtraLight",
  },
  sourceprolight: {
    fontSize: 20,
    fontFamily: "SourceCodePro-LightIt",
  },
});

就像集成 Google 字體一樣, useFonts 鉤子用于從 font 文件夾加載字體文件,根據(jù)字體是否成功加載,返回 truefalse 的值。

如果 fontsLoaded 不為真,即 useFonts 鉤子中指定的字體沒有成功加載,我們將返回一個 Loading… 文本。否則,我們渲染應(yīng)用組件并使用已加載的自定義字體。

如上述模擬器輸出所示,第一段具有 default 樣式的文本使用默認(rèn)的 fontFamily 樣式,而接下來的兩段文本分別使用了 SourceCodePro-ExtraLightSourceCodePro-Light 字體家族來設(shè)置文本樣式。

在React Native中使用自定義字體時常見的陷阱

在React Native中使用自定義字體時,你可能會遇到一些缺點:

  • 字體族名稱不匹配:如前文所述,確保字體族名稱一致性至關(guān)重要。例如,如果你將一個字體作為 SourceCodePro-ExtraLight.otf 導(dǎo)入,但隨后以不同的路徑或文件名加載到應(yīng)用程序中,例如 /assets/fonts/SourceCodePro-ExtraLight.ttf,這將導(dǎo)致應(yīng)用程序拋出錯誤,因為存在 fontFamily 名稱不匹配的情況。
  • 使用不受支持的字體格式:在使用自定義字體時,驗證你正在使用的系統(tǒng)(iOS,Android 或網(wǎng)頁)是否支持你正在使用的字體格式(例如,.ttf,.otf)非常重要。如果不支持,可能會在開發(fā)過程中出現(xiàn)意外錯誤。
  • 性能影響:在React Native應(yīng)用程序中添加自定義字體時,請注意它們的文件大?。ㄒ詋b/mb為單位)。大型字體文件可能會顯著增加應(yīng)用程序的加載時間,特別是在加載自定義字體時。

總結(jié)

如本文所探討的,將自定義字體集成到React Native應(yīng)用程序中不僅僅是技術(shù)上的提升,更是一種改善用戶體驗的策略性方法。無論是使用Expo還是React Native CLI,這個過程都將大大提升你的應(yīng)用的美觀度和可用性。

以上就是在React Native中添加自定義字體的方法詳解的詳細(xì)內(nèi)容,更多關(guān)于React Native添加自定義字體的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • React實現(xiàn)動態(tài)輪播圖的使用示例

    React實現(xiàn)動態(tài)輪播圖的使用示例

    輪播組件是常見的一種方式,用來展示圖像、信息或者是廣告,本文就來介紹一下React實現(xiàn)動態(tài)輪播圖的使用示例,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • 一文帶你掌握React類式組件中setState的應(yīng)用

    一文帶你掌握React類式組件中setState的應(yīng)用

    這篇文章主要為大家詳細(xì)介紹了介紹了React類式組件中setState的三種寫法以及簡單討論下setState?到底是同步的還是異步的,感興趣的可以了解下
    2024-02-02
  • React實現(xiàn)生成和導(dǎo)出Word文檔的方法詳解

    React實現(xiàn)生成和導(dǎo)出Word文檔的方法詳解

    React是一個流行的JavaScript庫,用于構(gòu)建現(xiàn)代前端應(yīng)用程序,本文將深入探討如何在React中生成和導(dǎo)出Word文檔,感興趣的小伙伴可以學(xué)習(xí)一下
    2023-09-09
  • 解決React報錯Property value does not exist on type HTMLElement

    解決React報錯Property value does not exist&n

    這篇文章主要為大家介紹了React報錯Property value does not exist on type HTMLElement解決方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • 在?React?中如何從狀態(tài)數(shù)組中刪除一個元素

    在?React?中如何從狀態(tài)數(shù)組中刪除一個元素

    這篇文章主要介紹了在?React?中從狀態(tài)數(shù)組中刪除一個元素,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-03-03
  • React新擴展函數(shù)setState與lazyLoad及hook介紹

    React新擴展函數(shù)setState與lazyLoad及hook介紹

    這篇文章主要介紹了React新擴展函數(shù)setState與lazyLoad及hook,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-12-12
  • react?umi?刷新或關(guān)閉瀏覽器時清除localStorage方式

    react?umi?刷新或關(guān)閉瀏覽器時清除localStorage方式

    這篇文章主要介紹了react?umi?刷新或關(guān)閉瀏覽器時清除localStorage方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 詳解react的兩種動態(tài)改變css樣式的方法

    詳解react的兩種動態(tài)改變css樣式的方法

    這篇文章主要介紹了詳解react的兩種動態(tài)改變css樣式的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • react如何獲取state的值并更新使用

    react如何獲取state的值并更新使用

    這篇文章主要介紹了react如何獲取state的值并更新使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • React配置Redux并結(jié)合本地存儲設(shè)置token方式

    React配置Redux并結(jié)合本地存儲設(shè)置token方式

    這篇文章主要介紹了React配置Redux并結(jié)合本地存儲設(shè)置token方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01

最新評論