ReactNative-调用iOS原生方法

栏目: IOS · 发布时间: 6年前

内容简介:React native 调用原生接口实现起来比较简单,自定义接口类PushManager,需要实现RCTBridgeModule协议,导入RCT_EXPORT_MODULE宏定义.React native导入本地原生模块:调用原生模块方法:

React native 调用原生接口实现起来比较简单,自定义接口类PushManager,需要实现RCTBridgeModule协议,导入RCT_EXPORT_MODULE宏定义.

#import 
  
#import
#import

@interface PushManager : NSObject<RCTBridgeModule>

@end
#import "PushManager.h"

@implementation PushManager

RCT_EXPORT_MODULE();

- (NSDictionary *)baseInfomation {
    return @{ @"name": @"FlyElephant" };
}

RCT_EXPORT_METHOD(showMessage:(NSString *)message type:(NSString *)type)
{
    RCTLogInfo(@"FlyElephant 本地调用 %@---%@---", message, type);
}

@end

React native导入本地原生模块:

import {
    Text,
    View,
    TouchableHighlight,
    NativeModules,
    NativeEventEmitter,
} from 'react-native';

const PushManager = NativeModules.PushManager;

调用原生模块方法:

 PushManager.showMessage("消息推送","local");

原生模块还支持回调函数的调用,iOS提供回调方法:

RCT_EXPORT_METHOD(blockCallbackEvent:(RCTResponseSenderBlock)callback)
{
    NSArray *events=@[@"Callback ", @"Block ", @"FlyElephant"];
    callback(@[[NSNull null],events]);
}

JavaScript回调处理:

                            PushManager.blockCallbackEvent((error, events) => {
                                if (error) {
                                    console.error(error);
                                } else {
                                    console.log("回调结果:" + events);
                                }
                            });

作者:FlyElephant

链接:https://www.jianshu.com/p/455e0b32623e


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

人件(原书第3版)

人件(原书第3版)

[美] Tom DeMarco、[美] Timothy Lister / 肖然、张逸、滕云 / 机械工业出版社 / 2014-8 / 69.00元

在软件管理领域,很少有著作能够与本书媲美。作为经久不衰的畅销书,本书深刻地洞察到软件开发的最大问题不在于技术,而在于人。人的因素并不容易解决,一旦解决了,你将更有可能获得成功。 本书是软件管理领域的传奇经典,被誉为“对美国软件业影响最大的一本书”。全书从管理人力资源、创建健康的办公环境、雇用并留用正确的人、高效团队形成、改造企业文化和快乐工作等多个角度阐释了如何思考和管理软件开发的最大问题—......一起来看看 《人件(原书第3版)》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

html转js在线工具
html转js在线工具

html转js在线工具