首页
学习
活动
专区
圈层
工具
发布

React Native 开发心得分享

是否有必要学 react-native?​ 先说一个结论:RN ≠ 原生,别指望会个 react 就能写出靠谱的原生应用。...但如果学 RN 只是为了避免不用学 android 和 iOS 等原生技术就能写 app,那便不建议学习。...Expo​ Expo 是基于 React Native 并整合大量常用的 native module(Expo SDK),像原生的功能如相册,相机,蓝牙等功能,在 expo 都是直接集成的,相当于封装原生的...模拟器无法请求本地 api​ 由于一开始是在 Web 端进行调试开发的,所以没留意到这个问题,直到切换到安卓模拟器之后发现模拟器无法请求本地后端服务,在IOS 端暂无这问题。...adb reverse tcp:6001 tcp:6001 此时安卓模拟器便可正常请求本地后端服务的资源,IOS 端并未有该问题。

1.5K31
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    老板说,2 天开发一个 App,双端支持,我是怎么做到的

    这对于不太熟悉 iOS 和 Android 原生开发的前端开发者来说,简直是福音。话又说回来,如果想看源码,人家也没拦着你,因为生态是开源的。2....社区与支持最让人欣慰的是,Expo 背后有一个活跃的社区。你可以随时在GitHub上提出问题,或者浏览别人已经解决的类似问题。除此之外,Expo 的文档非常详细,新手也能很快上手。...我遇到的一些问题就是在 docs 上找答案,比如如何本地构建,如何弹出原生模块,因为有可能需要做一些原生开发。...如果你需要使用某些非常特殊的原生功能,Expo 可能并不能完全满足你的需求。在这种情况下,你可能需要“弹出”Expo(也就是所谓的“eject”),从而使用纯粹的 React Native 环境。...这时候,你就要自己管理所有原生模块了。不过,对于大多数应用开发者来说,特别是那些不太熟悉原生开发的前端,Expo 已经足够强大。

    1.1K10

    Expo与Flutter:如何选择合适的移动框架

    在本文中,我将提出并回答十个可操作的问题,这些问题将帮助您确定适合您特定用例的技术,以便您自信地说:“我选择 Expo/Flutter 是因为 X、Y 和 Z。”...这就是为什么我们需要提出正确的问题来为您的项目选择合适的技术。 选择 Expo 和 Flutter 的 10 个问题 1. 您是否拥有 React/Dart 知识?...在 Expo 中,相机被抽象化,您可以使用 expo-camera 包来渲染原生 iOS 和 Android 相机视图。 虽然看起来是一个很小的区别,但它会影响某些项目的关键要求。...唯一的缺点是,在构建看起来像原生 iOS 应用程序的应用程序时,使用 Material Design 组件 比较困难(尤其是针对两个平台的自适应样式)。...如果您仍然不确定,让我帮助您快速了解一下: 您应该选择 Expo,如果您: 已经拥有 React 经验或代码 想要使用一个代码库构建 Web 和移动应用程序 想要使用原生平台组件 需要访问最新的原生平台

    1.4K10

    React Native推送通知:完整的操作指南

    原生平台特定的通知服务(FCM/APNs) Android和iOS平台都提供了用于接收推送通知的原生平台特定API 适用于安卓设备的Firebase云消息传递(FCM) 苹果推送通知服务(APNs)适用于...iOS设备 我们可以使用React Native Firebase库来在Android上集成FCM,使用 push-notification-ios 库来在iOS上集成APNs。...解决设置推送通知时的常见问题 开发人员在使用 Expo 通知和 Notifee 时常常会遇到一些常见的问题。...让我们看看这些问题的原因以及如何解决它们: 我无法在裸 React Native 应用中运行 Expo 通知:这是因为 Expo 通知库依赖于其他 Expo 库。...要解决这个问题,请转到 Expo 通知安装文档并遵循设置步骤。 Notifee 无法在 Expo 项目中运行:不幸的是,截至撰写本文时,这仍然是一个持续存在的问题。

    5.8K10

    H5 手机 App 开发入门:技术篇

    这样的话,只要写一次 React 页面,就能分别编译成 iOS 和安卓的原生 App。这就是 React Native 项目的由来。 ?...(3)React Native 的问题 React Native 的想法虽然很美好,但是实际开发中出现了各种各样的问题。...最主要的一个问题是, UI 抽象层翻译出来的 iOS 和安卓原生页面,做不到完全一致,尤其是复杂页面,样式或功能存在差异。编译出来两个平台的原生 App 往往是一个正常,另一个会出现各种奇怪的小毛病。...如果你想用 React Native 做到 iOS 和安卓体验一致,并且充分发挥原生控件的功能,就需要同时熟悉 React Native、iOS、安卓三个平台,这对开发者的要求实在太高了。...它为了解决 React Native 的平台差异问题,采用了一个完全不同的方案。 它自己实现了一套控件。打包的时候,会把这套控件打包进每一个 App,因此不存在调用原生控件的问题。

    8K41

    小记React Native与原生通信(iOS端)

    一、原生与RN通信 先做点准备工作叭~ 通过react-native init创建一个RN的新项目,此后将会得到一个内部带有ios和android目录的文件夹。把这两个目录下的文件换成自己的项目。...2、 RN页面跳原生页面及调用原生方法 RCTBridgeModule是定义好的protocol,实现该协议的类,会自动注册到iOS代码中对应的Bridge中。...此时,单纯通过导航跳转就无法解决该问题了。 在初始化RCTRootView之时,通过initWithBridge:(RCTBridge *)bridge方法将要展示的页面路径通过属性传递给RN。...react-native bundle --entry-file index.js --platform ios --dev false --bundle-output release_ios/main.jsbundle...勾选第一和第三选项 3) 打包发布 xCode->Product->Archive打ipa包 三、调试中遇见的一点小问题 iOS真机调试,reload的时候永远没反应,摇一摇弹出的调试界面也差了好几个按钮

    7.2K10

    使用umi开发react-native应用

    笔者在Web端习惯使用 umi 后,就变得越来越“懒”,什么问题都用这一锤子解决。 当工作中涉及到 react-native(后文简称:RN)应用的内容时,发现 umi 暂时没有支持RN的打算。...下游可以使用: React Native CLI:RN 官方开发/打包工具; expo:不需要搭建 iOS 和 Android 开发环境,工程目录干净清爽,添加 RN 依赖方便快捷; haul:第三方.../masked-view RN0.60.0 及以上版本有自动链接功能,Android 会自动搞定这些react-navigation的原生依赖,但对于iOS,待 yarn 安装完成后,还需要进到 ios.../async-storage请按照https://github.com/react-native-community/async-storage安装; 安装完成后,记得进到 ios 目录使用 pod 安装原生依赖...:cd ios && pod install && cd -,之后记得使用yarn ios和yarn android重新编译,启动原生 App。

    7.4K30

    快速创建React Native App

    本文向大家分享如何快速构建React Native App以及在使用快速构建方案中可能存在的一些问题及解决方案。...npm run ios 将APP运行在iOS设备上,仅仅Mac系统支持,且需要安装Xcode。...然后用Expo扫码屏幕上的二维码,aa就可以运行在Expo上了。 ? 提示:为了确保Expo App能够正常访问到你的PC,你需要确保你的手机和PC处于同一网段内或者他们能够联通。...问题分析: 在通过create-react-native-app命令创建一个React Native项目的时候,出现这个问题的原因是npm 5的一个bug所致@npm@5 known issue tracking...如果,大家在开发原生模块中遇到问题可以在本文的下方进行留言,我看到了后会及时回复的哦。 另外也可以关注我的新浪微博,或者关注我的Github来获取更多有关React Native开发的技术干货。

    2.7K51

    快速创建React Native App

    本文向大家分享如何快速构建React Native App以及在使用快速构建方案中可能存在的一些问题及解决方案。...npm run ios 将APP运行在iOS设备上,仅仅Mac系统支持,且需要安装Xcode。...然后用Expo扫码屏幕上的二维码,aa就可以运行在Expo上了。 ? 提示:为了确保Expo App能够正常访问到你的PC,你需要确保你的手机和PC处于同一网段内或者他们能够联通。...问题分析: 在通过create-react-native-app命令创建一个React Native项目的时候,出现这个问题的原因是npm 5的一个bug所致@npm@5 known issue tracking...如果,大家在开发原生模块中遇到问题可以在本文的下方进行留言,我看到了后会及时回复的哦。 另外也可以关注我的新浪微博,或者关注我的Github来获取更多有关React Native开发的技术干货。

    2.8K10

    React Native 导航:示例教程

    在构建移动应用程序时,首要考虑的是如何处理用户在应用程序中的导航问题,例如屏幕的展示和屏幕之间的切换。 React Navigation 是 React Native 最著名的导航库之一。...React Navigation 是用 JavaScript 编写的,并不直接使用 iOS 和 Android 上的原生导航 API。相反,它重新创建了这些 API 的某些子集。...React Native Navigation 有一点不同,它直接使用 iOS 和 Android 上的原生导航 API,这使得它能够提供更加原生的外观和感觉。...堆栈导航器还提供了类似于原生 iOS 和 Android 的过渡效果和手势。 注意,一个应用程序可以有多个堆栈导航器。...则利用了原生 API;iOS 上的 UINavigationController 和 Android 上的 Fragment,这样导航的行为就会与原生构建的应用程序一样。

    2.8K10

    React Native iOS原生模块开发实战|教程|心得

    React Native iOS原生模块的。...开发iOS原生模块的主要流程 在这里我把构建React Native iOS原生模块的流程概括为以下三大步: 编写原生模块的相关iOS代码; 暴露接口与数据交互; 导出React Native原生模块;...原生模块开发实战 在这里我们就以开发一个从相册获取照片并裁切照片的实战项目,来具体讲解一下如何开发React Native iOS原生模块的。...编写原生模块的相关iOS代码 这一步我们需要用到XCode。 首先我们用XCode打开React Native项目根目录下的iOS项目,如图: ? 接下来呢,我们就可以编写iOS代码了。...如果,大家在开发原生模块中遇到问题可以在本文的下方进行留言,我看到了后会及时回复的哦。 另外也可以关注我的新浪微博,或者关注我的Github来获取更多有关React Native开发的技术干货。

    2.3K60

    在React Native中构建启动屏

    在这个教程中,我们将演示如何在React Native中构建一个启动屏幕。我们将指导你如何使用 react-native-splash-screen 为iOS和Android应用构建出色的欢迎界面。...完成后的应用将如下图所示 为什么启动画面的图片大小很重要 为移动应用创建启动画面可能会有些棘手,你肯定不希望由于启动画面分辨率的不一致在某些设备上出现显示问题。例如,安卓设备的需求与iOS完全不同。...*/ yarn add react-native-splash-screen 为iOS构建一个启动屏幕 在你的终端中,使用下面的命令链接依赖项: cd ios // to enter into IOS...将内容模式设置为“aspect fit”,如下所示: 更改iOS启动屏幕颜色 你可能会问的下一个问题是“我如何在 React Native 中更改启动屏幕的背景颜色?”...请参考下面的截图: 构建一个Expo启动屏幕 到目前为止,我们已经探讨了如何在一个裸 React Native 应用中构建启动屏幕。

    4K10

    React-native,我们一起走过的坑。

    先说明一下我的运行环境: 1.我当时这个年代用的RN版本是0.55 2.使用的脚手架是create-react-native-app 调试 EJECT前(即生成那个android和ios文件前) 如果你像我那样...your own native builds 但是,是男人的话怎么能那么快eject的,所以这时就该大名鼎鼎的’Expo’登场了,你只需要在你的手机或者模拟器上安装上这个最新版的’Expo’软件,然后在你的本地项目运行命令...为了性能方便所有网络图片都要先设固定宽高(来自官方傲娇的解析) 像这样 <Image style={{width: 100, height: 100}} source={{uri: url}} /> 那么问题来了...解决方法: 1、使用Image自带的getSize方法先获取宽高 2、使用别的大神的组件React Native Fit Image 等 资源超过400kb左右不显示 所以说原生组件, 推荐使用别的组件库...:react-native-fast-image(要先装个glide,略为麻烦) 静态资源 source={require(‘.

    1.2K10

    expo

    https://docs.expo.dev/ https://github.com/expo/expo Expo 是一个开源平台,旨在帮助开发者构建可以在 Android、iOS 和 Web 上运行的通用原生应用...通过结合使用 React 和 JavaScript,开发者可以在一个统一的环境中构建跨平台的应用,而不需要切换不同的技术栈。...Expo 生态 Expo 提供了一个强大的生态系统,包括多个模块和工具,使得从开发到部署的每一步都能得到充分的支持。...例如,packages 目录包含了所有 Expo 模块的源代码,apps/expo-go 目录则包含了 Expo Go 的源代码,开发者可以在这里进行本地测试和定制开发。...在官方文档中,Expo 还提供了丰富的资源,包括教程、常见问题解答 (FAQ) 和开发指南,帮助开发者解决在使用过程中遇到的各种问题。 Expo 鼓励开发者为开源社区贡献代码。

    71110

    Flutter 与 React Native - 详细深入对比分析(2024 年)

    设置 React Native 需要更多的经验。React Native 的入门指南没有提供足够的细节和帮助来启动项目。不过,React Native 有 Expo。...Expo 是一套工具,可以大大简化构建 React Native 应用的过程。使用 Expo 客户端,您可以在构建应用时直接在手机上查看它们(无需通过 Android Studio 或 Xcode)。...Expo CLI 通过提供开发、日志、部署、迭代、编译等工具,简化了新 React Native 应用的创建过程。...调试在 React Native 中,调试可能会存在问题,尤其是当特定的异常或错误来源于应用程序的原生部分时。...注意:原生Android和iOS也支持热重载,但其功能相比React Native和Flutter的热重载要有限。

    3.1K01
    领券