DCloud_App_Array
DCloud_App_Array
  • 发布:2018-12-26 12:14
  • 更新:2024-09-25 09:11
  • 阅读:105638

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

要回复文章请先登录注册

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
1***@qq.com

1***@qq.com

这个原生插件跟第三方sdk是同一个意思吗
2020-04-07 09:56
1***@qq.com

1***@qq.com

我想问下创建项目的APPID怎么能和创建的应用列表里的APPID一样?点击购买时列表里没有,我创建了一个,然后包名用的本地创建的项目包名,可是我在选择原生插件的时候并没有我购买的啊,这里该怎么操作?求解答
2019-09-20 14:44
l***@126.com

l***@126.com

JAR的引入方法是一样的吗?
2019-01-26 00:12
DCloud_iOS_XHY

DCloud_iOS_XHY

回复 1***@qq.com :
您好,插件市场上有原生的插件,可以按照教程体验一下
2019-01-17 18:47
1***@qq.com

1***@qq.com

有实例吗
2019-01-11 13:26