DCloud_App_Array
DCloud_App_Array
  • 发布:2018-12-26 12:14
  • 更新:2023-12-26 11:23
  • 阅读:92934

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 诺墨 剑心无间

要回复文章请先登录注册

DCloud_App_Array

DCloud_App_Array (作者)

回复 swankytiger :
请单独发帖,按“提交Bug” 模板详细描述,提供截图说明
2021-01-19 20:59
swankytiger

swankytiger

发布插件,上传图片不成功,论坛,QQ群都没有人回,咋办呀
2021-01-19 15:50
chihiro_yy

chihiro_yy

我这边出现一个问题,我使用自定义基坐测试时完全没问题,然后提交云打包后,打完的包运行不了原生插件,但是只要插上电脑就可以
2020-11-20 19:21
西恩十月

西恩十月

购买付费插件有发-票吗?
2020-08-14 10:43
西恩十月

西恩十月

购买付费插件有发票吗?
2020-08-14 10:43
DCloud_App_Array

DCloud_App_Array (作者)

回复 6***@qq.com :
发布插件时分类选择“原生App SDK”,会自动显示价格输入框。
目前仅uni原生插件支持付费。
2020-05-22 17:28
6***@qq.com

6***@qq.com

怎么发布付费插件?
2020-05-22 14:03
CaesarHe

CaesarHe

回复 CaesarHe :
[system] API ‘requireNativePlugin’ is not yet implemented
2020-05-07 13:32
CaesarHe

CaesarHe

回复 CaesarHe :
报错:[system] API `requireNativePlugin` is not yet implemented
2020-05-07 13:32
CaesarHe

CaesarHe

为什么我无法使用uni.requireNativePlugin() API,使用直接报错[system] API `requireNativePlugin` is not yet implemented,我都是严格按照文档步骤去做的,我换了电脑、换了系统、换了版本、换了原生插件、换了项目等等等等,尝试了各种方法,全网都没有找到相关的坑
2020-05-07 13:31