”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 从 React 到 React Native 的旅程

从 React 到 React Native 的旅程

发布于2024-11-08
浏览:519

作为一名 React / JS 开发人员,您可能有这样的想法 “我应该学习 React Native 吗?” 这是一个公平的问题,也是我几年前问自己的问题。事实证明,学习 React Native 绝对是正确的决定。这让我成为了亚马逊的高级开发倡导者,我现在使用 React Native 跨 Android、Fire TV 和平板电脑设备构建应用程序。

如果您正在争论是否要超越网络应用程序,这里有一些关于为什么值得考虑的想法:

为什么要学习 React Native?

  • “一次学习,随处编写”的理念不仅仅局限于 iOS 和 Android,它现在还包括 tvOS、VisionOS 等平台,甚至像 React-native-macos 等桌面环境

  • 行业相关性:亚马逊、Meta、微软等大公司都在采用 React Native。 为什么?代码可重用性、成本效益高,并且允许您构建跨平台。

  • 强大的社区支持:React Native 在 GitHub 上拥有超过 100k star 和 24k fork,定期更新和积极开发。

  • 开发者满意度高:根据 React Native 现状调查,90% 的开发者会再次使用 React Native!

  • 统一生态系统:React Native社区围绕Expo集结,带来更快的改进、良好集成的第三方库和丰富的共享资源。

Journeying from React to React Native

  • 熟悉的开发者经验

React 与 React Native:异同

架构与编译

相似之处:

两者都使用通常称为“虚拟 DOM”的协调过程。此过程将一棵树与另一棵树进行比较,以确定 UI 的哪些部分需要更新。因此,它们都支持快速刷新,使您能够实时看到 UI 变化。

差异:

React 编译以利用 DOM 和 Web API 在 Web 浏览器中呈现。即使通过移动浏览器访问,它仍然受到浏览器功能的限制,并且对本机设备功能的访问受到限制。

另一方面,

React Native 编译为本机代码,允许直接访问特定于平台的 API 和功能。这意味着 React Native 应用程序可以利用相机访问、推送通知等设备功能,提供本机用户体验。因此,它采用了不同的架构方法,即所谓的“无桥”架构,并且它使用本机组件而不是 DOM。它使用 Turbo Native 模块并利用 JavaScript 接口 (JSI),允许 JavaScript 和本机代码之间直接通信。这种架构是新的,您可能会听到“新架构”这个术语。如果您有兴趣了解更多信息,我在上一篇文章中对此进行了介绍。

Journeying from React to React Native

JSX 和 Hooks

相似之处

两者都使用 JSX 来描述 UI 并支持 React hooks(useState、useEffect 等)。这使您可以在两个库中保持一致的编码风格和状态管理方法。

成分

相似之处

React 和 React Native 都遵循基于组件的架构,并且组件在底层遵循相同的生命周期方法。

差异:

  1. 组件导入:在React Native中,您可以从react-native导入UI组件,这与React不同,其中HTML元素是全局可用的。这种差异实际上是我最喜欢 React Native 的事情之一,因为你可以访问一组开箱即用的预构建组件,例如视图、文本、图像、TextInput、ScrollView。
  2. 特定于平台的组件:React Native 还提供为 iOS 和 Android 量身定制的开箱即用的组件和 API。
  3. 文本处理:在 React Native 中,所有文本都必须包装在 组件中,这与在 React 中文本可以直接放置在许多元素中不同。这可确保不同平台上文本的正确样式和行为,从而提高一致性和可访问性。
  4. 事件处理:React使用onClick进行点击事件,而React Native使用onPress进行触摸交互,体现了交互性质的不同。

Journeying from React to React Native

造型

相似之处

React 和 React Native 都提供了灵活的组件样式设计方法。它们都支持内联样式,允许您将样式直接应用于组件。此外,两者都可以创建可重用的样式对象。

差异

  1. 样式语言:React 通常使用 CSS 或 CSS-in-JS 库进行样式设置,而 React Native 使用基于 JavaScript 对象的样式系统,但有一些区别:
    • 属性名称:React Native 使用驼峰命名法作为属性名称(例如,fontSize 而不是 font-size)。
    • 值单位:在 React Native 中,您不需要宽度、高度或字体大小等属性的单位,它会自动假定尺寸以与密度无关的像素为单位。
  2. StyleSheet API:React Native 提供了 StyleSheet.create() 方法来创建样式对象。该 API 通过减少在每次渲染上重新创建样式对象的需要来提高性能。
  3. 样式应用:与 React 中的类名可用于应用样式不同,React Native 使用 style 属性将样式直接应用于组件。
  4. 有限的 CSS 子集:React Native 仅支持 CSS 属性的子集,重点关注那些对不同布局有意义的属性。这意味着某些特定于 Web 的属性(如 float)不可用,而其他属性(如 flex)可能表现不同。

Journeying from React to React Native

库和工具

相似之处

React 和 React Native 共享许多核心库。您可以使用相同的状态管理库(如 Redux、MobX)以及数据获取库(如 Axios 或 Fetch API)。

差异

导航: 虽然在 React 中您通常可能使用 React Router 进行 Web 导航,但 React Native 有自己的 React 导航库。这是因为 React (Web) 通常使用基于 URL 的导航,其中根据当前 URL 路径呈现不同的组件。而 React Native 使用基于堆栈的导航,模仿本机移动应用程序体验。屏幕彼此“堆叠”在一起,通过过渡将新屏幕推入堆栈或“弹出”它们。

?注意:在构建应用程序时,请记住将文件夹命名为“Screens”而不是“Pages”。

Journeying from React to React Native

测试:两个库的概念仍然相似,侧重于组件渲染和事件模拟,但具体的测试库有所不同。 React 使用 React 测试库,而 React Native 您将使用 React Native 测试库 (RNTL),但不要推迟,因为 RNTL 只是在 React 测试渲染器之上提供轻量级实用功能。

?由于 DOM 依赖关系,某些 React 库可能无法与所有 React Native 平台兼容,但是您可以在以下位置检查所有库的平台兼容性:(https://reactnative.directory)

Journeying from React to React Native

通过通用 React 应用程序缩小差距

如果您仍持观望态度,那么通用 React 应用程序的兴起确实是一个令人兴奋的领域,它进一步缩小了 React 和 React Native 之间的差距。通用 React 库和工具通常由 react-native-web 提供支持,使您能够从共享的 React Native 代码库创建在 iOS、Android 和 Web 上运行的跨平台应用程序。这使您可以共享导航、样式、状态管理和业务逻辑,从而节省您的时间和精力,同时尊重每种设备类型的独特约定。

因此,随着 DOM 和 Device 之间的界限不断模糊,拥抱 React Native 为令人兴奋的多平台应用程序开发世界打开了大门!

如果您准备好开始,请查看我最喜欢的资源的评论,或在下面评论您的资源⬇️

版本声明 本文转载于:https://dev.to/amazonappdev/journeying-from-react-to-react-native-21ep?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 我尝试过花岗岩。
    我尝试过花岗岩。
    花岗岩3.0 Granite 3.0 是一个开源、轻量级的生成语言模型系列,专为一系列企业级任务而设计。它原生支持多语言功能、编码、推理和工具使用,使其适合企业环境。 我测试了运行这个模型,看看它可以处理哪些任务。 环境设置 我在Google Colab中设置了Gr...
    编程 发布于2024-11-08
  • 掌握 JavaScript 函数:开发人员综合指南
    掌握 JavaScript 函数:开发人员综合指南
    JavaScript Functions A JavaScript function is a block of code designed to perform a particular task. A JavaScript function is executed when "...
    编程 发布于2024-11-08
  • Next.js 缓存:通过高效的数据获取来增强您的应用程序
    Next.js 缓存:通过高效的数据获取来增强您的应用程序
    Next.js 中的缓存不仅仅是为了节省时间,还在于减少冗余网络请求、保持数据新鲜并使您的应用程序像摇滚明星一样运行。 无论您是想将数据缓存更长时间还是按需刷新,Next.js 都能为您提供所需的所有工具。在本文中,我们将详细介绍如何在 Next.js 中有效地使用缓存 Next.js 扩展了 f...
    编程 发布于2024-11-08
  • 为什么我的 Go 模板条件检查失败?
    为什么我的 Go 模板条件检查失败?
    Go 模板:条件检查故障排除在 Go 模板渲染中,结构体字段的条件检查有时无法按预期工作。考虑以下示例,其中 bool 字段 isOrientRight 未正确计算:type Category struct { ImageURL string
    编程 发布于2024-11-08
  • 如何解决 MySQL 时区错误:Java 中的“服务器时区值中欧时间”?
    如何解决 MySQL 时区错误:Java 中的“服务器时区值中欧时间”?
    MySQL 连接器在 Java 数据库连接期间出现“服务器时区值中欧时间”错误使用建立数据库连接时会出现此问题Java 中的 MySQL 连接器。该错误消息表明提供的服务器时区值“中欧时间”无法识别或代表多个时区。要解决此问题,必须使用 serverTimezone 配置属性显式指定服务器时区值。一...
    编程 发布于2024-11-08
  • 为什么应该避免在 JSX Props 中使用箭头函数或绑定?
    为什么应该避免在 JSX Props 中使用箭头函数或绑定?
    为什么在 JSX Props 中使用箭头函数或 Bind 是禁忌使用 React 时,避免使用箭头函数或 Bind 非常重要在 JSX 属性中绑定。这种做法可能会导致性能问题和不正确的行为。性能问题在 JSX props 中使用箭头函数或绑定会强制在每次渲染时重新创建这些函数。这意味着:旧函数被丢弃...
    编程 发布于2024-11-08
  • 自动模式的 CSS 主题选择器 [教程]
    自动模式的 CSS 主题选择器 [教程]
    This tutorial shows you how to create a theme selector in Svelte, enabling multiple theme options for your website. It also includes an automatic them...
    编程 发布于2024-11-08
  • 了解 Java 中的静态实用方法
    了解 Java 中的静态实用方法
    在现代软件开发中,非常重视干净、可重用和有效的编码。 Java 中的一项功能对实现这一目标大有帮助,称为静态实用方法。本文将探讨什么是静态实用方法、它们的好处、常见用例以及有效实现这些方法的最佳实践。 什么是静态实用方法? 静态实用方法是属于类的方法,而不是属于类的实例。这些方法是使...
    编程 发布于2024-11-08
  • ## 如何在 JavaScript 中限制函数执行:自定义解决方案与库解决方案
    ## 如何在 JavaScript 中限制函数执行:自定义解决方案与库解决方案
    通过自定义实现实现 JavaScript 中的简单节流使用 JavaScript 时,控制函数执行速率至关重要。节流函数限制函数调用的频率,防止繁重的处理或重复的用户操作。在这篇文章中,我们提出了一个简单的自定义节流函数来实现此目的,而不依赖于 Lodash 或 Underscore 等外部库。 提...
    编程 发布于2024-11-08
  • 了解 WebSocket:React 开发人员综合指南
    了解 WebSocket:React 开发人员综合指南
    Understanding WebSockets: A Comprehensive Guide for React Developers In today’s world of modern web applications, real-time communication is ...
    编程 发布于2024-11-08
  • 如何在 macOS 上安装并启用 Imagick for PHP
    如何在 macOS 上安装并启用 Imagick for PHP
    如果您在 macOS 上工作并且需要安装 Imagick for PHP 8.3,则可能会遇到默认安装较旧版本 PHP(例如 PHP 8.0)的问题。在这篇文章中,我将引导您完成确保 Imagick 已安装并针对 PHP 8.3 正确配置的步骤。 第 1 步:通过 Homebrew ...
    编程 发布于2024-11-08
  • 如何使用 JavaScript 为对象数组添加附加属性?
    如何使用 JavaScript 为对象数组添加附加属性?
    扩展具有附加属性的对象数组编程中普遍存在的任务涉及使用附加属性增强现有对象数组。为了说明这个概念,请考虑包含两个元素的对象数组:Object {Results:Array[2]} Results:Array[2] [0-1] 0:Object id=1 name: "R...
    编程 发布于2024-11-08
  • 如何解决 CSS 中可变字体的文本笔划问题?
    如何解决 CSS 中可变字体的文本笔划问题?
    文本描边难题:解决 CSS 兼容性问题使用 -webkit-text-lines 创建引人注目的文本效果是网页设计师的一项基本技术。但是,当将此属性与可变字体一起使用时,可能会出现意外的笔划行为。这种不一致不仅限于 Chrome,而是不同浏览器中更普遍的问题。问题的症结:可变字体和笔画冲突可变字体具...
    编程 发布于2024-11-08
  • C++ 中的私有虚拟方法:平衡封装和重写
    C++ 中的私有虚拟方法:平衡封装和重写
    了解 C 中私有虚拟方法的好处 在面向对象编程中,私有方法封装实现细节并限制其在一个班级。然而,在 C 中,虚函数提供后期绑定并允许对象的多态行为。通过结合这些概念,私有虚拟方法提供了独特的优势。考虑以下用法,其中 HTMLDocument 继承自多个基类:class HTMLDocument : ...
    编程 发布于2024-11-08
  • 斋浦尔数据科学研究所:传统与技术的邂逅
    斋浦尔数据科学研究所:传统与技术的邂逅
    斋浦尔,粉红之城,长期以来一直是一座拥有丰富文化遗产、雄伟宫殿和充满活力的传统的城市,但这座城市的另一个特征是教育和技术进步。这是通过斋浦尔的几个数据科学研究所推出的,通过这些机构引导学生和专业人士进入快速变化的技术世界。 这些机构融合了传统与创新,在培养这座城市的未来科技人才方面发挥着重要作用。在...
    编程 发布于2024-11-08

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3