0

0

如何在 React Native SVG 中正确使用自定义字体

心靈之曲

心靈之曲

发布时间:2025-12-25 22:44:02

|

420人浏览过

|

来源于php中文网

原创

如何在 React Native SVG 中正确使用自定义字体

react native svg 的 `` 组件原生不支持自定义字体(截至 v13.4.0),需通过 `` 包裹标准 rn `` 并动态设置 `key` 属性来实现渲染与更新。

在 React Native 项目中,使用 Expo 的 useFonts 成功加载自定义字体(如 'Robo Numbers')后,常规的 react-native 或 react-native-paper 的 组件可正常应用 fontFamily 样式。但 react-native-svg 的 组件并不继承 RN 的字体注册机制——它底层依赖原生 SVG 渲染逻辑,无法识别通过 expo-font 注册的字体名,因此即使显式声明 fontFamily="Robo Numbers",也会回退到系统默认字体。

官方文档与源码均未提供对自定义字体的直接支持方案,社区也普遍确认该功能当前缺失(v13.x 系列)。所幸, 提供了一种稳定、轻量的绕过方案:它允许在 SVG 坐标系中嵌入标准 React Native 元素,从而复用已加载的字体资源。

✅ 正确实现方式如下:

Cutout老照片上色
Cutout老照片上色

Cutout.Pro推出的黑白图片上色

下载
import { ForeignObject, Text as SvgText } from 'react-native-svg';
import { Text } from 'react-native';

// 假设已在组件顶层调用 useFonts({...})
const CountdownDisplay = ({ countdown }: { countdown: number }) => {
  return (
    
       10 ? '#f8f0c1' : 'orange'
      }}>
        {countdown}
      
    
  );
};

⚠️ 关键注意事项:

  • ForeignObject 必须设置 动态 key 属性(如 key={countdown}),否则其子元素不会随状态更新而重渲染 —— 这是常见陷阱,尤其在定时器(如 setInterval)驱动的数字变化场景中;
  • x/y 定义 SVG 内部坐标原点,width/height 应合理覆盖文本区域,避免截断;
  • ForeignObject 在 Android 和 iOS 上兼容性良好,但不支持 Web 端(若需多端一致,请结合平台判断或降级处理);
  • 避免嵌套过深或高频重绘大量 ForeignObject,可能影响性能。

? 补充建议:若项目重度依赖 SVG 文本样式,可考虑将数字文本预渲染为 (通过字体转 SVG 轮廓工具离线生成),但开发成本显著升高;对于大多数动态场景,ForeignObject + key 是当前最实用、可维护的解决方案。

相关专题

更多
android开发三大框架
android开发三大框架

android开发三大框架是XUtil框架、volley框架、ImageLoader框架。本专题为大家提供android开发三大框架相关的各种文章、以及下载和课程。

238

2023.08.14

android是什么系统
android是什么系统

Android是一种功能强大、灵活可定制、应用丰富、多任务处理能力强、兼容性好、网络连接能力强的操作系统。本专题为大家提供android相关的文章、下载、课程内容,供大家免费下载体验。

1703

2023.08.22

android权限限制怎么解开
android权限限制怎么解开

android权限限制可以使用Root权限、第三方权限管理应用程序、ADB命令和Xposed框架解开。详细介绍:1、Root权限,通过获取Root权限,用户可以解锁所有权限,并对系统进行自定义和修改;2、第三方权限管理应用程序,用户可以轻松地控制和管理应用程序的权限;3、ADB命令,用户可以在设备上执行各种操作,包括解锁权限;4、Xposed框架,用户可以在不修改系统文件的情况下修改应用程序的行为和权限。

1933

2023.09.19

android重启应用的方法有哪些
android重启应用的方法有哪些

android重启应用有通过Intent、PendingIntent、系统服务、Runtime等方法。本专题为大家提供Android相关的文章、下载、课程内容,供大家免费下载体验。

252

2023.10.18

Android语音播放功能实现方法
Android语音播放功能实现方法

实现方法有使用MediaPlayer实现、使用SoundPool实现两种。可以根据具体的需求选择适合的方法进行实现。想了解更多语音播放的相关内容,可以阅读本专题下面的文章。

340

2024.03.01

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

115

2025.12.24

拼豆图纸在线生成器
拼豆图纸在线生成器

拼豆图纸生成器有PixelBeads在线版、BeadGen和“豆图快转”;推荐通过pixelbeads.online或搜索“beadgen free online”直达官网,避开需注册的诱导页面。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

84

2025.12.24

俄罗斯搜索引擎yandex官方入口地址(最新版)
俄罗斯搜索引擎yandex官方入口地址(最新版)

Yandex官方入口网址是https://yandex.com。用户可通过网页端直连或移动端浏览器直接访问,无需登录即可使用搜索、图片、新闻、地图等全部基础功能,并支持多语种检索与静态资源精准筛选。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

553

2025.12.24

JavaScript ES6新特性
JavaScript ES6新特性

ES6是JavaScript的根本性升级,引入let/const实现块级作用域、箭头函数解决this绑定问题、解构赋值与模板字符串简化数据处理、对象简写与模块化提升代码可读性与组织性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

155

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 2.9万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 0.9万人学习

React核心原理新老生命周期精讲
React核心原理新老生命周期精讲

共12课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号