rn调用原生view方法,不是属性,直接通过view名来调用

import {  NativeModules } from 'react-native';             

原生view

class MegaMediaPlayerRNManager : SimpleViewManager<MediaLiveStreamVideoView>() {
    override fun getName(): String {
        return "RNTPlay"
    }

        ..

    @ReactMethod()
    fun release() {
        //这里是需要调用原生的方法
     }

}

//RN调用

try {

                if (Platform.OS === 'android') {

                  NativeModules.RNTPlay.release();

        //NativeModules.你在原生定义的View名称.view里面的方法名

                }

              }catch (error){

              }

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值