封装iOS原生资源库link到项目供ReactNative使用

ReactNative发现到现在,已经支持其在基础上编写原生代码,具有访问平台所有能力。如今在GitHub上已经有很多的RN组件满足大家使用了,但当出现特定需求时候呢?RN不支持你所需要的原生特性的时候,这个时候就需要自己去封装该特性了。
参考ReactNative中文网,一个“原生模块”就是一个实现了“RCTBridgeModule”协议的Objective-C类,其中RCT是ReaCT的缩写.

在此我只是说明怎么去实现封装iOS原生资源库,具体你需要什么的需求则自己去写了。
1.首先我们先init一个RN项目
react-native init Demo


image.png

2.RN项目创建完了,运行里面iOS项目,确保没问题;没问题后可以不用管了,接下来我们可以去创建资源库

3.首先我们定义一个文件夹react-native-maillist(RN官方声明第三方定义插件名称),index.js导入文件,package.json文件可以通过npm init生成,再一个我们在里面定义一个iOS文件夹;

4.Xcode/file->new -> Project 创建一个资源包放到iOS文件夹目录下

image.png

组件名称在MailList.h文件中

image.png

为了实现RCTBridgeModule协议,你的类需要包含RCT_EXPORT_MODULE()宏。这个宏也可以添加一个参数用来指定在Javascript中访问这个模块的名字。如果你不指定,默认就会使用这个Objective-C类的名字。
这里我们是指定名称的,然后你可以在里面声明给JavaScript调用的方法然后导出(具体操作可参考中文网)

image.png

5.在静态库中配置路径

image.png

路径输入 $(SRCROOT)/../../react-native/React, 选择recurvise

6.在react-native-maillist文件下index.js中导出该插件

image.png

7.将插件复制到我们的项目工程的node_modules中
然后大家通过react-native link xxx(插件全称) 命令集成进工程中,

也可以手动导入,在Libraries中 选择Add Files to "工程名", 选择node_modules中要导入的插件mailList.xcodeproj添加进来,

然后Build Phases中添加静态.a文件进去

image.png

最终我们在RN工程中可以通过js调用

image.png

这样我们可以自己定义自己的资源库了,后期再告诉大家怎么用pod管理我们的资源库,有不对的地方,希望大佬可以指出,谢谢~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,367评论 25 709
  • 准备工作: 创建ReactNative工程 我们需要先创建一个ReactNative工程,使用如下命令创建。 re...
    五八四十阅读 5,568评论 2 4
  • 撕开来,很多都无相关性,只是好事者捏造和想象。 需要凛冬的真实。
    咸叔说阅读 1,454评论 0 0
  • 马拉松就是比谁有耐力,长寿也是比谁有耐力,看谁笑到最后也是。所以,我们中国人比谁都有耐力。司马懿是三国里耐力最好的...
    水原素阅读 1,315评论 0 1
  • 前几天,我的两个孩子相继发高烧。先是一岁多的小女儿,由于那几天是爷爷奶奶照顾,估计没控制好饮食,感冒咳嗽低烧嗓子哑...
    易家文化刘爱云阅读 4,427评论 2 1

友情链接更多精彩内容