Android与RN远程过程调用的原理

Android与RN远程过程调用的原理是通过通信协议进行远程过程调用。RPC(Remote Procedure Call)是分布式系统常见的一种通信方式,从跨进程到跨物理机已经有几十年历史。

在React Native中,通信机制是一个C++实现的桥,打通了Java和JS,实现了两者的相互调用。

React-native 跨平台原理

参考React-native 跨平台原理
在这里插入图片描述

  • 主要是通过Virtual DOM来实现跨平台的,只要有Virtual DOM就可以通过不同的渲染引擎来实现view的跨平台。React native就是通过和native之间不断通信来实现UI的绘制等一系列操作,
  • js和native通信:Java端会把所有要暴漏的Java类的信息封装成Config传给JS,然后根据Config生成对应Java类的Javascript镜像对象,以及要暴漏的方法,在JS中调用这个镜像对象的方法就会被转发到对应的Java对象上,
  • UI main thread 不断询问JS thread并且请求数据,如果数据有变,则更新UI界面。

在这里插入图片描述

  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你想在 React Native 中调用原生方法,可以使用 React Native 提供的 Native Modules。 首先,在原生代码中创建一个方法,然后将其导出到 React Native 中。例如在 iOS 项目中,可以在 `AppDelegate.m` 文件中添加以下方法: ``` #import <React/RCTBridge.h> #import <React/RCTBridgeModule.h> @interface MyModule : NSObject <RCTBridgeModule> @end @implementation MyModule RCT_EXPORT_MODULE(); RCT_EXPORT_METHOD(myMethod:(NSString *)myArgument callback:(RCTResponseSenderBlock)callback) { // 在这里实现你的方法逻辑 NSString *myResponse = @"这是我的响应"; callback(@[[NSNull null], myResponse]); } @end ``` 在上面的代码中,我们定义了一个名为 `myMethod` 的方法,并将其导出到 React Native 中。此方法接受一个字符串参数 `myArgument` 和一个回调函数 `callback`,并在回调函数中返回一个响应字符串。 接下来,在 React Native 中调用这个方法。可以使用 `NativeModules` 模块来访问原生方法。例如: ``` import { NativeModules } from 'react-native'; const { MyModule } = NativeModules; MyModule.myMethod('这是我的参数', (error, response) => { if (error) { console.error(error); } else { console.log(response); } }); ``` 在上面的代码中,我们使用 `NativeModules` 访问原生模块 `MyModule`,并调用其中的 `myMethod` 方法。此方法接受一个字符串参数和一个回调函数,该回调函数在方法完成后被调用,并传递错误对象和响应字符串作为参数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值