发布 React Native 0.59
欢迎来到 React Native 的 0.59 版本!这是一个重要的版本,包含 88 位贡献者的 644 次提交。贡献也以其他形式存在,所以**感谢您**维护问题、培养社区并向人们教授 React Native。本月带来了一些备受期待的变化,我们希望您会喜欢它们。
🎣 Hooks 来了
React Hooks 是此版本的一部分,它允许您在组件之间重用有状态逻辑。关于 hooks 有很多讨论,但如果您还没有听说过,请查看下面的一些精彩资源
- Hooks 简介解释了我们为什么要在 React 中添加 Hooks。
- Hooks 概述是内置 Hooks 的快速概览。
- 构建自己的 Hooks演示了自定义 Hooks 的代码重用。
- 理解 React Hooks探索了 Hooks 开启的新可能性。
- useHooks.com展示了社区维护的 Hooks 配方和演示。
务必在您的应用中尝试一下。我们希望您像我们一样发现重用令人兴奋。
📱 更新后的 JSC 意味着性能提升和 Android 64 位支持
React Native 使用 JSC(JavaScriptCore)来驱动您的应用程序。Android 上的 JSC 已经有几年历史了,这意味着许多现代 JavaScript 特性都不受支持。更糟糕的是,与 iOS 的现代 JSC 相比,它的性能很差。在这个版本中,所有这些都改变了。
感谢 @DanielZlotin、@dulmandakh、@gengjiawen、@kmagiera 和 @kudo 的出色工作,JSC 已经赶上了过去几年。这带来了 64 位支持、现代 JavaScript 支持和巨大的性能改进。感谢他们现在也使之成为一个可维护的过程,这样我们就可以利用未来的 WebKit 改进而无需那么多繁琐的工作,感谢 Software Mansion 和 Expo 使这项工作成为可能。
💨 通过内联 require 实现更快的应用启动
我们希望通过默认情况下帮助人们拥有高性能的 React Native 应用,并正在努力将 Facebook 的优化带给社区。应用程序按需加载资源,而不是减慢启动速度。此功能称为“内联 require”,因为它允许 Metro 识别需要延迟加载的组件。具有深层和多样化组件架构的应用程序将获得最大的改进。
我们需要社区告诉我们它在默认开启之前是如何工作的。当您升级到 0.59 时,将有一个新的 metro.config.js
文件;将选项翻转为 true 并给我们您的反馈!在性能文档中阅读有关内联 require 的更多信息以基准测试您的应用。
🚅 精益核心正在进行中
React Native 是一个庞大而复杂的项目,拥有复杂的代码库。这使得代码库对贡献者而言更难接近,更难以测试,并且作为开发依赖项而言过于臃肿。精益核心是我们通过将代码迁移到单独的库以实现更好管理来解决这些问题的努力。过去几个版本已经迈出了第一步,但让我们认真起来。
您可能会注意到,现在有更多组件已正式弃用。这是个好消息,因为现在这些功能都有了积极维护它们的所有者。请注意警告消息,并为这些功能迁移到新的库,因为它们将在未来的版本中删除。下表显示了组件、其状态以及您可以将您的使用迁移到何处。
组件 | 已弃用? | 新家 |
---|---|---|
AsyncStorage | 0.59 | @react-native-community/react-native-async-storage |
ImageStore | 0.59 | expo-file-system 或 react-native-fs |
MaskedViewIOS | 0.59 | @react-native-community/react-native-masked-view |
NetInfo | 0.59 | @react-native-community/react-native-netinfo |
Slider | 0.59 | @react-native-community/react-native-slider |
ViewPagerAndroid | 0.59 | @react-native-community/react-native-viewpager |
在接下来的几个月里,将有更多组件遵循这条路径走向更精益的核心。我们正在寻求这方面的帮助——请前往精益核心总览贡献一份力量。
👩🏽💻 CLI 改进
React Native 的命令行工具是开发人员进入生态系统的入口,但它们存在长期问题并且缺乏官方支持。CLI 工具已移至新仓库,并且专门的维护者小组已经取得了一些令人兴奋的改进。
现在日志格式化得更好了。命令现在几乎立即运行——您会立即注意到差异
🚀 升级到 0.59
我们听取了您对React Native 升级过程的反馈,我们正在采取措施改进未来版本的体验。要升级到 0.59,我们建议使用rn-diff-purge
来确定您的当前 React Native 版本和 0.59 之间有哪些变化,然后手动应用这些变化。一旦您将项目升级到 0.59,您就可以使用新改进的 react-native upgrade
命令(基于 rn-diff-purge
!)来升级到 0.60 及更高版本。
🔨 破坏性变更
0.59 中的 Android 支持已根据 Google 的最新建议进行了清理,这可能会导致现有应用出现潜在的破坏。此问题可能会表现为运行时崩溃和一条消息:“您需要将 Theme.AppCompat 主题(或其子孙)与此活动一起使用”。我们建议更新您项目的 AndroidManifest.xml
文件,确保 android:theme
值是 AppCompat
主题(例如 @style/Theme.AppCompat.Light.NoActionBar
)。
react-native-git-upgrade
命令在 0.59 中已被删除,取而代之的是新改进的 react-native upgrade
命令。
🤗 感谢
许多新贡献者帮助了从 flow 类型生成原生代码和解决 Xcode 警告——这些是学习 React Native 工作原理并为更大的利益做出贡献的好方法。谢谢你们!未来请留意类似问题。
虽然这些是我们指出的亮点,但还有许多其他值得兴奋的地方。要查看所有更新,请查看更新日志。0.59 是一个巨大的版本——我们迫不及待地想让您尝试一下。
今年剩下的时间里,我们还将带来更多改进。敬请期待!