React Native 0.79发布 - 更快的工具及更多改进
React Native 0.79版本发布了。
此版本在多个方面进行了性能改进,并修复了一些漏洞。首先,得益于延迟哈希技术,Metro的启动速度变快了,并且对包导出提供了稳定支持。由于JS包压缩方式的改变等原因,Android的启动时间也将得到改善。
亮点
- 新的Metro功能
- JSC转移到社区维护的包
- iOS:与Swift兼容的原生模块注册
- Android:更快的应用启动速度
- 移除远程JS调试功能
Metro:更快的启动速度和包导出支持
此版本搭载了Metro 0.82。该版本使用延迟哈希技术,通常能将首次运行yarn start的速度提高3倍以上(在大型项目和单体仓库中提升更明显),让你的日常开发体验和持续集成(CI)构建速度更快。
 x rm-rf STmPDIR/metro-fite-map-;DEBUG-Met bsky-metro82-bench git:(main) x rm-rf STMPDIR/metro-fite-map-;DEBUG-H
t=bundle.js index.js t=bundle.js index.js yarn run v1.22.22)
| 之前 | 之后 | |
|---|---|---|
| 首次打包时间 | - | - |
同样在Metro 0.82中,我们将package.json中的exports和imports字段解析提升到稳定状态。exports解析在React Native 0.72中引入,imports支持由社区贡献添加,现在在React Native 0.79上,所有项目默认都会启用这两个功能。这提高了与现代npm依赖项的兼容性,并为组织项目开辟了新的、符合标准的方式。
JSC转移到社区维护的包
作为减少React Native API 表面的一部分工作,我们正在将JavaScriptCore(JSC)引擎转移到一个由社区维护的包:@react-native-community/javascriptcore。
此更改不会影响使用Hermes的用户。从React Native 0.79开始,你可以按照README中的安装说明使用社区支持版本的JSC。React Native核心提供的JSC版本在0.79中仍然可用,但我们计划在不久的将来将其移除。将JSC转移到社区维护的包中,能让我们更频繁地更新JSC版本,并为你提供最新功能。社区维护的JSC版本将与React Native遵循不同的发布计划。
iOS:与Swift兼容的原生模块注册
在这个版本中,我们改进了将原生模块注册到React Native运行时的方式。新方法遵循官方文档中描述的组件注册方法。从这个版本的React Native开始,你可以通过修改package.json文件来注册模块。我们在ios属性中引入了一个新的modulesProvider字段:
"codegenConfig": {"ios": {"modulesProvider": {"JS模块名称": "用于纯C++ 原生模块的ObjC模块提供器或符合RCTTurboModule的类"}}
}
代码生成工具会根据你的package.json文件创建所有相关代码。如果你使用纯C++原生模块,则需要遵循以下推荐配置:
配置应用中的纯C++原生模块
对于纯C++原生模块,你需要添加一个新的ObjectiveC++类,将C++原生模块与应用的其他部分连接起来:
CppNativeModuleProvider.h
#import <Foundation/Foundation.h>
#import <ReactCommon/RCTTurboModule.h>
NS_ASSUME_NONNULL_BEGIN
@interface <YourNativeModule>Provider : NSObject <RCTModuleProvider>
@end
CppNativeModuleProvider.mm
NS_ASSUME_NONNULL_END
#import "<YourNativeModule>Provider.h"
#import <ReactCommon/CallInvoker.h>
#import <ReactCommon/TurboModule.h>
#import "<YourNativeModule>.h"
@implementation NativeSampleModuleProvider
- (std::shared_ptr<facebook::react::TurboModule>)getTurboModule:(const facebook::react::ObjCTurboModule::InitParams &)params{return std::make_shared<facebook::react::NativeSampleModule>(params.jsInvoker);
}
@end
通过这种新方法,我们统一了应用开发者和库维护者注册原生模块的方式。库可以在它们的package.json中指定相同的属性,代码生成工具会处理剩下的工作。这种方法解决了我们在0.77版本中引入的限制,该限制阻止了使用Swift AppDelegate注册纯C++原生模块。如你所见,这些更改都不会修改AppDelegate,生成的代码对用Swift和Objective-C实现的AppDelegate都有效。
Android:更快的应用启动速度
我们还进行了一项更改,大幅提升Android应用的启动时间。从这个版本开始,我们将不再在APK中压缩JavaScript包。以前,Android系统需要在应用启动前解压JavaScript包,这在应用启动期间导致了明显的速度减慢。从这个版本开始,我们默认会提供未压缩的JavaScript包,所以你的Android应用通常会启动得更快。
Margelo团队在Discord应用上测试了这个功能,并获得了显著的性能提升:Discord的交互时间(TTI)减少了400毫秒,在三星A14上测试,通过一行代码的更改实现了12%的速度提升。另一方面,存储未压缩的包会导致应用在用户设备上占用更多空间。如果你对此有所顾虑,可以在app/build.gradle文件中使用enableBundleCompression属性来切换此行为。
react {// ...// 如果你想压缩JS包(启动较慢,占用空间较少)enableBundleCompression = true// 如果你不想压缩JS包(启动较快,占用空间较多)enableBundleCompression = false// 默认值为`false`
}
请注意,此版本中APK的大小会增加,但你的用户在下载APK时不会承担额外的下载大小成本,因为从网络下载的APK是经过压缩的。
重大变更
移除远程JS调试功能
作为持续改进调试体验工作的一部分,我们正在移除通过Chrome进行的远程JS调试功能。这种旧的调试方法在React Native 0.73中已被弃用,并改为运行时可选启用。请使用React Native DevTools进行现代且可靠的调试。这也意味着React Native不再与react-native-debugger社区项目兼容。对于想要使用第三方调试扩展(如Redux DevTools)的开发者,我们推荐使用Expo DevTools插件,或者集成这些工具的独立版本。
内部模块更新为export语法
作为现代化JavaScript代码库工作的一部分,我们在react-native内部更新了多个实现模块,统一使用export语法替代module.exports。我们总共更新了约46个API,可在变更日志中查看。此更改对现有导入有细微影响:
情况1:默认导出
// 已更改 - require()语法
// 旧
const ImageBackground = require('react-native/Libraries/Image/ImageBackground');
// 新
const ImageBackground = require('react-native/Libraries/Image/ImageBackground').default;
// 未更改 - import语法
import ImageBackground from 'react-native/Libraries/Image/ImageBackground';
// 推荐 - 根导入
import {ImageBackground} from 'react-native';
情况2:次要导出
这种模式的情况很少,使用根'react-native'导入时不受影响。
// 未更改 - require()语法
const BlobRegistry = require('react-native/Libraries/Blob/BlobRegistry');
// 未更改 - 带解构的require()语法
const {register, unregister} = require('react-native/Libraries/Blob/BlobRegistry');
// 已更改 - 作为单个对象的import语法
// 旧
import BlobRegistry from 'react-native/Libraries/Blob/BlobRegistry';
// 新
import * as BlobRegistry from 'react-native/Libraries/Blob/BlobRegistry';
// 未更改 - 带解构的import语法
import {register, unregister} from 'react-native/Libraries/Blob/BlobRegistry';
// 推荐 - 根导入
import {BlobRegistry} from 'react-native';
我们预计此更改的影响非常有限,特别是对于用TypeScript编写并使用import语法的项目。请检查是否有类型错误并更新代码。
提示:强烈推荐使用根react-native导入
一般来说,我们强烈建议从根路径'react-native'导入,以避免未来出现不必要的重大变更。在下一个版本中,我们将弃用深度导入,作为更好定义React Native公共JavaScript API的一部分(见RFC)。
其他重大变更
此列表包含一系列我们认为可能对你的产品代码有轻微影响、值得注意的其他重大变更。
- 盒阴影和滤镜中无效的无单位长度:为了使React Native更符合CSS/Web规范,我们现在不再支持
box-shadow和filter中的无单位长度。这意味着,如果你之前使用1 1 black这样的box-shadow,将无法渲染。你应该指定单位,如1px 1px black。 - 从normalize-color中移除对不正确hwb()语法的支持:为了使React Native更符合CSS/Web规范,我们现在限制了
hwb()的一些无效语法。过去,React Native支持用逗号分隔的值(例如hwb(0, 0%, 100%)),现在不再支持(你应该迁移到hwb(0 0% 100%))。你可以在此处关于此更改的内容。 - Libraries/Core/ExceptionsManager导出更新:作为现代化React Native JS API工作的一部分,我们更新了
ExceptionsManager,现在它默认导出一个ExceptionsManager对象,并将SyntheticError作为次要导出。
升级到0.79
对于现有项目,请使用React Native升级助手查看不同React Native版本之间的代码更改,同时参考升级文档。
要创建新项目:
npx @react-native-community/cli@latest init MyProject --version latest
如果你使用Expo,React Native 0.79将在即将发布的Expo SDK 53中作为React Native的默认版本得到支持。
信息
0.79现在是React Native的最新稳定版本,0.76.x已不再受支持。更多信息请查看React Native的支持政策。我们计划在不久的将来发布0.76的最终停用更新。
标签
工程
亮点
- Metro:更快的启动速度和包导出支持
- JSC转移到社区维护的包
- iOS:与Swift兼容的原生模块注册
- Android:更快的应用启动速度
重大变更
- 移除远程JS调试功能
- 内部模块更新为
export语法 - 其他重大变更
总结
React Native 0.79版本带来多项更新,涵盖性能提升、功能改进和重大变更。
- 亮点功能
- Metro优化:Metro 0.82利用延迟哈希技术,使启动速度提升3倍以上,还稳定支持
package.json的exports和imports字段解析,增强与现代npm依赖的兼容性。 - JSC迁移:JavaScriptCore(JSC)引擎转移至社区维护的
@react-native-community/javascriptcore包,社区版JSC更新更频繁,React Native核心提供的JSC版本后续将被移除,但不影响使用Hermes的用户。 - iOS模块注册改进:在iOS中,可通过修改
package.json的modulesProvider字段注册原生模块,统一了开发者和库维护者的注册方式,解决了0.77版本中纯C++原生模块与SwiftAppDelegate注册的限制。 - Android启动加速:Android默认不再压缩JavaScript包,提升了应用启动速度,如Discord应用测试时交互时间减少400毫秒,速度提升12% 。若担心空间占用,可在
app/build.gradle中通过enableBundleCompression属性切换。
- Metro优化:Metro 0.82利用延迟哈希技术,使启动速度提升3倍以上,还稳定支持
- 重大变更
- 调试方式变更:移除通过Chrome的远程JS调试功能,推荐使用React Native DevTools,且不再兼容react-native-debugger社区项目,开发者可用Expo DevTools插件或集成独立工具进行第三方调试扩展。
- 语法更新:约46个内部模块从
module.exports更新为export语法,对导入有细微影响,推荐从根路径'react-native'导入以避免后续问题,未来版本将弃用深度导入。 - 其他变更:为符合CSS/Web规范,不再支持
box-shadow和filter中的无单位长度、hwb()的部分旧语法;ExceptionsManager导出更新,默认导出ExceptionsManager对象,SyntheticError作为次要导出。
小伙伴们,你们项目使用跨平台解决方案了吗?
使用的RN还是Flutter?
欢迎在评论区留言交流。
相关文章:
React Native 0.79发布 - 更快的工具及更多改进
React Native 0.79版本发布了。 此版本在多个方面进行了性能改进,并修复了一些漏洞。首先,得益于延迟哈希技术,Metro的启动速度变快了,并且对包导出提供了稳定支持。由于JS包压缩方式的改变等原因,Android的启动时间也…...
封装红黑树实现map和set
前言: 之前我们学习了set与map容器的如何使用,红黑树的实现。接下来我们来看看如何通过封装红黑树,实现我们自己的set与map 相关文章:oi!让我来给你唠唠咋实现红黑树☝️-CSDN博客 超详细介绍map&…...
解码AI大脑:Claude的思维显微镜与语言炼金术
(前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站)。 一、多语言思维实验:Claude的“概念空间”如何运转? 跨语言谜题:反义词的…...
中科岩创基坑自动化监测解决方案
1.行业现状 城市基坑开挖具有施工风险高、施工难度大等特点。由于地下土体性质、荷载条件、施工环境的复杂性,单根据地质勘察资料和室内土工试验参数来确定设计和施工方案,往往含有许多不确定因素,对在施工过程中引发的土体性状、环境、邻近建…...
机器学习01-支持向量机(SVM)(未完)
参考浙大 胡浩基老师 的课以及以下链接: https://blog.csdn.net/m0_74100344/article/details/139560508 https://blog.csdn.net/2301_78630677/article/details/132657023 https://blog.csdn.net/lsb2002/article/details/131338700 一、一些定义 T是倒置&…...
CUDA编译器nvcc
nvcc(NVIDIA CUDA Compiler)是 NVIDIA 提供的 CUDA 编译器,用于编译 .cu 文件(CUDA C/C 代码)。它支持多种参数来控制编译过程,包括 GPU 架构优化、CUDA 库链接、调试选项等。以下是 nvcc 常用参数分类详解…...
Elasticsearch 系列专题 - 第一篇:Elasticsearch 入门
Elasticsearch 是一个功能强大的开源分布式搜索和分析引擎,广泛应用于日志分析、实时搜索、数据可视化等领域。本篇将带你了解 Elasticsearch 的基本概念、安装方法以及简单操作,帮助你快速上手。 1. 什么是 Elasticsearch? 1.1 Elasticsearch 的定义与核心概念 Elasticse…...
leetcode_数组 189. 轮转数组
189. 轮转数组 给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数 示例 1: 输入: nums [1,2,3,4,5,6,7], k 3输出: [5,6,7,1,2,3,4] 示例 2: 输入:nums [-1,-100,3,99], k 2输出:[3,99,-1,-100] 思…...
Python基础全解析:从输入输出到字符编码的深度探索
一、Python程序交互的基石:Print函数详解 1.1 基础输出功能 # 输出数字 print(20.5) # 输出浮点数:20.5 print(0b0010) # 输出二进制数:10# 输出字符串 print(Hello World!) # 经典输出示例# 表达式计算 print(4 4 * (2-1)…...
[ctfshow web入门] web32
前置知识 协议相关博客:https://blog.csdn.net/m0_73353130/article/details/136212770 include:include "filename"这是最常用的方法,除此之外还可以 include url,被包含的文件会被当做代码执行。 data://:…...
指针数组 vs 数组指针
一、指针数组:「数组装指针」—— 每个元素都是指针 🔍 核心定义 语法:类型* 数组名[长度]; ([]优先级高于*,先形成数组,元素是指针)本质:一个 数组,数组的每个元素是 …...
鸿蒙开发中的并发与多线程
文章目录 前言异步并发 (Promise和async/await)多线程并发并发能力选择耗时任务并发执行场景常见业务场景 常驻任务并发执行场景常见业务场景 传统共享内存并发业务长时任务并发执行场景常见业务场景 并发任务管理线程间通信同语言线程间通信(ArkTS内)线…...
TCP和UDP的区别是什么?
1. 基本特性: TCP: 面向连接:在数据传输开始前,TCP需要在通信双方建立连接(三次握手)。可靠性:TCP保证数据的可靠传输,通过确认应答、重传机制、数据包顺序等确保数据无误到达。流量控制和拥塞…...
MySQL 函数(入门版)
目录 一、字符串函数 1、常用的字符串函数 2、函数演示 3、具体案例 二、数值函数 1、常用的数值函数 2、函数演示 3、具体案例 三、日期函数 1、常用的日期函数 2、函数演示 3、具体案例 四、流程函数 1、常用的流程函数 2、函数演示 3、具体案例 在MySQL中&a…...
Simulink中Signal Builder在新版中找不到怎么办
在较新的MATLAB版本中,新版Simulink中的Signal Builder用Signal Editor作为替代工具。 signal builder not shown in matlab - MATLAB Answers - MATLAB Central signalBuilderToSignalEditor 1.打开上面第二个链接 2.点击拷贝 3.然后在命令行中粘贴 4.然后就会…...
【补题】P10424 [蓝桥杯 2024 省 B] 好数(数位dp)
题意: 一个整数如果按从低位到高位的顺序,奇数位(个位、百位、万位……)上的数字是奇数,偶数位(十位、千位、十万位……)上的数字是偶数,我们就称之为“好数”。 给定一个正整数 N…...
SvelteKit 最新中文文档教程(19)—— 最佳实践之身份认证
前言 Svelte,一个语法简洁、入门容易,面向未来的前端框架。 从 Svelte 诞生之初,就备受开发者的喜爱,根据统计,从 2019 年到 2024 年,连续 6 年一直是开发者最感兴趣的前端框架 No.1: Svelte …...
Cursor编程-从入门到精通__0409
早期的Github Copilot 最近更新了,支持Agent编程,字节跳动Trae使用(免费),但成熟程度不如Cursor,Cursor前50次免费 Copilot VS Cursor*** 1,Cursor VSCode 二次开发,IDE级别 2&…...
VSCode、clangd、mingw 配置与使用
1.安装 安装如下软件: VSCodeclangd 扩展mingw-w64 2.配置 配置好 mingw-w64 到用户环境中。 在项目中设置 .clangd 扩展,设置 argument //setting.json"clangd.arguments": ["--query-driverD:\\Development\\Tools\\mingw64\\bin…...
深度学习处理文本(14)
使用Transformer进行序列到序列学习 正是序列到序列学习让Transformer真正大放异彩。与RNN相比,神经注意力使Transformer模型能够处理更长、更复杂的序列。要将英语翻译成西班牙语,你不会一个单词一个单词地阅读英语句子,将其含义保存在记忆中,然后再一个单词一个单词地生…...
核心案例 | 湖南汽车工程职业大学无人机操控与编队技术实验室
核心案例 | 湖南汽车工程职业大学无人机操控与编队技术实验室 为满足当今无人机行业应用需求,推动无人机技术的教育与实践深度融合,北京卓翼智能科技有限公司旗下品牌飞思实验室与湖南汽车工程职业大学强强联手,共同建设无人机操控与编队技术…...
Oracle 查看后台正在执行的 SQL 语句
在 Oracle 数据库中,要查看后台正在执行的 SQL 语句,可以通过查询动态性能视图(Dynamic Performance Views)或使用监控工具来实现。 1. 查询动态性能视图 (1) 查看当前活跃会话及其执行的 SQL 使用 v$session 和 v$sql 视图关联…...
SpringBoot整合MinIO快速入门:实现分布式文件存储与管理
文章目录 一、MinIO是什么?为什么选择它?1.1 什么是MinIO?1.2 核心优势 二、本地快速搭建MinIO服务2.1 Docker一键部署2.2 访问管理界面2.3 创建存储桶(Bucket) 三、SpringBoot集成MinIO客户端3.1 添加Maven依赖3.2 配…...
我的NISP二级之路-03
目录 一.ISMS 二.IP 三.http 四.防火墙 五.文件 解析 解析 六.攻击 解析 解析 七.风险管理工程 八.信息系统安全保护等级 九.我国信息安全保障 一.ISMS 1.文档体系建设是信息安全管理体系(ISMS)建设的直接体现,下列说法不正确的是: A&#…...
Vue框架的Diff算法
以下是关于 Diff 算法 的系统梳理: 一、Diff 算法的核心目标 最小化 DOM 操作:通过虚拟 DOM 对比,找出真实 DOM 的最小变更集高效节点复用:尽可能复用相同节点,减少创建/销毁开销顺序优化处理:优先处理高频变更场景(如列表尾部追加)保证渲染正确性:正确处理组件状态和…...
Oracle 表空间高水位收缩全攻略
1. 概述 本文档是针对某个特定用户表空间收缩的文档,实际操作要结合生产库具体情况。主要包括以下几个流程: 收集当前数据库相关信息降低数据库表高水位线Resize 收缩数据文件 具体细节详见以下章节。 2. 时间规划 操作类型预估时间实际时间数据库信…...
ESModule和CommonJS在Node中的区别
ESModule console.log(require);//>errorconsole.log(module);//>errorconsole.log(exports);//>errorconsole.log(__filename);//>errorconsole.log(__dirname);//>error全部报错commonjs console.log(require);console.log(module);console.log(exports);co…...
floyd模板
B3647 【模板】Floyd - 洛谷 f l o y d floyd floyd 模板 对于 f l o y d floyd floyd 算法来说时间复杂度为 O ( n 3 ) O(n^3) O(n3) ,不如跑 n n n 遍 h e a p _ d i j k s t r a heap\_dijkstra heap_dijkstra 算法 题目大意: 给出一张由 n n …...
力扣刷题-热题100题-第34题(c++、python)
23. 合并 K 个升序链表 - 力扣(LeetCode)https://leetcode.cn/problems/merge-k-sorted-lists/?envTypestudy-plan-v2&envIdtop-100-liked 顺序合并 合并两个有序链表作为子函数,创建一个空链表,然后对含有多个链表的数组进…...
括号匹配问题--栈
括号匹配问题 栈的应用代码概览栈操作函数详解1.初始化栈(stackInit)2.向栈中压入元素(stackpush)3.获取栈顶元素(stacktop)4.弹出栈顶元素(stackpop)5.销毁栈(stackdest…...
