• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

javascript - ReactNative - 无法从 native 模块调用函数

[复制链接]
菜鸟教程小白 发表于 2022-12-13 13:15:46 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我有现有的 ReactNative 项目。

现在我正在尝试连接到一些 native 库。我一直在通过官方Native modules guide .

在我的代码中,我添加了包含此代码的 CalendarManager.h 文件:

#import <Foundation/Foundation.h>
#import "RCTBridgeModule.h"

@interface CalendarManager : NSObject <RCTBridgeModule>

@end

我也有 CalendarManager.m 文件:

#import "CalendarManager.h"

@implementation CalendarManager

RCT_EXPORT_MODULE();

RCT_EXPORT_METHOD(addEventNSString *)name locationNSString*)location)
{
   //RCTLogInfo(@"retending to create an event %@ at %@", name, location);
}

@end

此文件通过 XCode 添加到与 AppDelegate.m 文件相同的级别。

在我的 javascript 代码中,我这样做:

import React from 'react-native';

然后我像这样调用该函数:

var cmanager = React.CalendarManager;
cmanager.addEvent('Birthday Party', '4 Privet Drive, Surrey');

我能够构建项目,但是当我在模拟器中运行它时(包管理器启动后),我得到了令人讨厌的红色错误:

Cannot read property 'addEvent' of undefined. 

在我看来,我错过了一些东西,但我不确定是什么?



Best Answer-推荐答案


您需要使用 NativeModules 来访问您的自定义原生组件。

试试这个:

import { NativeModules } from 'react-native';
var CalendarManager = NativeModules.CalendarManager;
CalendarManager.addEvent('Birthday Party', '4 Privet Drive, Surrey');

关于javascript - ReactNative - 无法从 native 模块调用函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36065160/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap