六、uni-app 原生插件开发02 - uni-app 原生插件初体验

让代码在真机上跑起来

在前面一篇文章中,我们在模拟器上运行了一个 uni-app 程序,本节教程我们在 iOS 真机上跑一下项目,肤浅的窥探一下 APP 是如何在 iOS 设备上运行起来的。
在 01 教程中,我们对 uni-app 有了一个大致了解,明确了我们的角色 -- 开发原生插件,供上层调用。
前面我们新建了一个 wb-kyc-demo 项目,之前我们是运行在模拟器上,现在我们连接手机到电脑上,连接成功之后,选择在真机设备上运行。

六、uni-app 原生插件开发02 - uni-app 原生插件初体验_第1张图片
image.png

运行一会之后,我们发现手机上安装了一个名为 HBuilder 的 APP,IDE 底部控制台输出如下:

19:37:20.717 项目 'wb-kyc-demo' 开始编译...
19:37:21.360 编译器版本:2.4.6
19:37:21.368 请注意运行模式下,因日志输出、sourcemap以及未压缩源码等原因,性能和包体积,均不及发行模式。
19:37:21.369 正在编译中...
19:37:25.015  DONE  Build complete. Watching for changes...
19:37:25.023 项目 'wb-kyc-demo' 编译成功.
19:37:25.264 正在建立手机连接...
19:37:27.341 正在同步手机端程序文件...
19:37:28.849 同步手机端程序文件完成
19:37:30.089 联机调试并非打包,调试基座 HBuilder 是默认的测试包,权限、图标都不可自定义。只有在点菜单"发行-发行为原生安装包"时才能自定义这些设置
19:37:30.110 iOS9.0及以上系统需要在"设置"-"通用"-"设备管理"(或"描述文件")中信任DCloud企业证书(Digital Heaven开头的证书)才可以正常使用
19:37:30.134 如手机上HBuilder调试基座未启动,请手动启动。如应用未更新,请在手机上杀掉基座进程重启

从控制台输出我们可以看到,我们手机上安装了一个企业证书签名的 APP,首次调试的话,我们需要信任一下企业证书。

六、uni-app 原生插件开发02 - uni-app 原生插件初体验_第2张图片
image.png

信任证书之后,打开 APP,可以进行页面调试。

由此我们可以看出 HBuilder X 这个 IDE 屏蔽了一切和 iOS 开发的细节,比如:

  • 组装一个包含 weex 框架、资源文件的 iOS 项目
  • 编译项目,生成 ipa 文件并用企业证书签名
  • 将 ipa 包安装到设备上

调试基座

注意,上面我们提到的 ipa 包,在 uni-app 开发中,称为调试基座,我将其简称为基座
讲这么多,就是为了引出这个概念,在 uni-app 中,调试基座有两类:

  • 默认调试基座
  • 自定调试基座

运行在手机上的基座,属于默认的调试基座,IDE 帮我们生成的。
我们在 HBuilder X 中,我们先窥探一下自定义调试基座。


六、uni-app 原生插件开发02 - uni-app 原生插件初体验_第3张图片
image.png

默认的可以满足我们所有的需求么?
答案是否定的,当 uni-app 需要调用原生插件的时候,我们就需要制作自定义基座了,这里可以粗略的思考一下原因。

原生插件本质上就是一块 native 代码,uni-app 要调用这一块代码的话,这块代码必须打进 ipa 中,由于我们要调用哪些原生插件是未知的,所以默认基座没有办法满足我们如此差异化的需求,所以,一旦涉及到调用原生插件的时候,我们就必须自定义基座

iOS插件使用的基本套路

开发之前,我们要知道在 uni-app 中,是如何使用插件的。

uni-app 中有两种方式可以使用原生插件:

  • 使用插件市场的插件
  • 使用本地插件

本节我们将如何从插件市场获取原生插件。

在开发者后台配置应用

在第一篇文章中,我们注册了一个 DCloud 开发者账号,并将其登录在 HBuilder X 中了。

我们登录我们的开发者管理台 https://dev.dcloud.net.cn/ ,在管理台我们可以看到我们创建的 APP 信息。

六、uni-app 原生插件开发02 - uni-app 原生插件初体验_第4张图片
image.png

在插件市场为项目添加插件

进入 原生插件市场,原生插件市场有开发者发布的一些插件,此处我们以 原生增强提示框插件 来演示。

进入插件页面,点击右侧的购买按钮,可以看到如下弹框,我们在弹框中选择添加插件的项目。

六、uni-app 原生插件开发02 - uni-app 原生插件初体验_第5张图片
image.png

点击下一步,绑定 APP 包名,此处我在 iOS 包名输入框中输出 APP 的bundle id。

六、uni-app 原生插件开发02 - uni-app 原生插件初体验_第6张图片
image.png

回到 HBuilder X 项目中,在 manifest.json 文件的 APP 原生插件配置项中,我们原则云端插件,可以在弹框中看到我们刚刚添加的 原生增强提示框插件

勾选插件。

六、uni-app 原生插件开发02 - uni-app 原生插件初体验_第7张图片
image.png

原生增强提示框插件 主页,提供了插件接入示例代码,我们将接入示例代码添加到 index.vue 的

你可能感兴趣的:(六、uni-app 原生插件开发02 - uni-app 原生插件初体验)