DCloud_App_Array
DCloud_App_Array
  • 发布:2018-12-26 12:14
  • 更新:2022-05-12 10:20
  • 阅读:73277

uni-app原生插件(native plugin)使用说明

分类:uni-app

新版原生插件开发文档已发布,请移步:https://nativesupport.dcloud.net.cn/

此文档将不再更新维护

过去DCloud的app产品虽然也可以自行扩展原生能力,但文档和接口设计的不太好,也没有云打包原生插件的能力,也没有插件市场。
如今这些问题都解决了。
HBuilderX1.4起,提供了全新的插件开发方式(同weex插件),支持云打包原生插件,插件市场也同步上线。
按以下步骤操作使用原生插件

第一步:购买或下载uni-app原生插件

从HBuilderX1.9.0版本开始,uni原生插件支持设置为免费或收费,为了保护插件开发者权益,收费插件只支持云端打包,不提供插件下载

  • 使用前需先登录uni原生插件市场,在插件详情页中购买,免费插件也可以在插件市场0元购。购买后才能够云端打包使用插件
    购买插件时请选择正确的appid,以及绑定正确包名
  • 对于免费的uni原生插件,也可以先下载到本地再提交云端打包(不推荐)
    详情参考:本地uni-app原生插件提交云端打包

第二步:使用自定义基座打包uni原生插件 (注:请使用真机运行自定义基座)

使用uni原生插件必须先提交云端打包才能生效,购买插件后在应用的manifest.json页面的“App原生插件配置”项下点击“选择云端插件”,选择需要打包的插件:


如果插件已下载到本地,点击“选择本地插件”,选择需要打包的插件
直接云端打包后无法打log,不利于排错,所以一般先打一个自定义基座,把需要的原生插件打到真机运行基座里,然后在本地写代码调用调试。
注意,自定义基座不是正式版,真正发布时,需要再打正式包。使用自定义基座是无法正常升级替换apk的。

第三步:开发调试uni-app原生插件

  • 在vue页面或nvue页面引入这个原生插件。
    使用uni.requireNativePlugin的api,参数为插件的id。
    例如:
    const dcRichAlert = uni.requireNativePlugin('DCloud-RichAlert')
  • 根据插件市场的插件介绍页面的文档编写js代码,调用其能力
    注意如果前端代码需要给原生sdk传路径,则需要传手机文件的绝对路径。

第四步:打包发布

使用自定义基座开发调试uni-app原生插件后,不可直接将自定义基座apk作为正式版发布。
应该重新提交云端打包(不能勾选“自定义基座”)生成正式版本。

uni-app原生插件使用常见问题

如果你想自己开发原生插件,参考
uni-app原生插件开发指南
Android:https://ask.dcloud.net.cn/article/35416
iOS:https://ask.dcloud.net.cn/article/35415

更多uni-app原生插件文档参考:uni-app原生插件开发指南

7 关注 分享
Trust 5个萝卜 sonicsunsky Neil_HL LuxSun 诺墨 剑心无间

要回复文章请先登录注册

qingyou

qingyou

我购买的插件 填写的包名是跟我云端打包的安卓包名是一样的为什么提示和插件绑定的不一样 呢
2022-05-12 10:20
DCloud_App_Array

DCloud_App_Array (作者)

回复 s***@gmail.com :
5+ App项目(5+ API)不能调用uni原生插件,请升级到uni-app项目。
2021-12-06 16:18
s***@gmail.com

s***@gmail.com

h5 的plus 怎么调用原生插件?
2021-12-02 15:56
DCloud_App_Array

DCloud_App_Array (作者)

回复 7***@qq.com :
请先在原生环境中调试好插件功能,再制作uni原生插件提交云端打包。
2021-11-29 11:58
7***@qq.com

7***@qq.com

基座打包有次数限制,那我在制作原生插座期间怎么调试?要调试就只能云打包基座?
2021-11-28 20:06
醉挽清风

醉挽清风

回复 CaesarHe :
你好 这个问题怎么解决的
2021-08-25 15:12
醉挽清风

醉挽清风

回复 CaesarHe :
你好 这个问题你是怎么解决的
2021-08-25 15:12
g***@163.com

g***@163.com

id绑定错误能修改吗
2021-08-03 10:12
1***@qq.com

1***@qq.com

能不能使用两个插件?
2021-07-26 17:25
a***@zhw.name

a***@zhw.name

此设计的 方法回调函数 是不是不会销毁 会不会导致内存泄漏
2021-05-13 09:53