百度智能小程序 打开另一个小程序
swan.navigateToSmartProgram
基础库 1.10.8 版本开始支持。在工具和真机中的实现有区别,详见 API 实现差异。
解释:打开另一个小程序。
方法参数
Object object
object 参数说明
属性名 | 类型 | 必填 | 默认值 | 说明 |
---|---|---|---|---|
appKey |
String |
是 |
要打开的小程序 App Key(使用线上版 appkey 和 envVersion 配合使用) |
|
path |
String |
否 |
打开的页面路径,如果为空则打开首页。path 中 ? 后面的部分会成为 query,在小程序的 App.onLaunch、App.onShow 和 Page.onLoad 的回调函数中可以获取到 query 数据。query的参数中不能包含(_naExtParams,_baiduboxapp,callback,upgrade)这几个字段,因为他们都是端上的保留字,使用后参数会出现接受不到的情况 |
|
extraData |
Object |
否 |
需要传递给目标小程序的数据,目标小程序可在 App.onLaunch(),App.onShow() 中获取到这份数据 |
|
success |
Function |
否 |
接口调用成功的回调函数 |
|
fail |
Function |
否 |
接口调用失败的回调函数 |
|
complete |
Function |
否 |
接口调用结束的回调函数(调用成功、失败都会执行) |
|
envVersion |
String |
否 |
release |
要打开的小程序版本(develop 开发版,trial 体验版) |
示例
图片示例
代码示例 1
在开发者工具中打开
<view class="wrap">
<button type="primary" bindtap="navigateToSmartProgram">navigateToSmartProgram</button>
</view>
Page({
navigateToSmartProgram() {
swan.navigateToSmartProgram({
// 打开目标小程序的AppKey,开发版AppKey可在开发者工具中预览获取
appKey: 'AppKey',
path: '', // 打开的页面路径,如果为空则打开首页
extraData: {
foo: 'baidu'
},
success: res => {
console.log('navigateToSmartProgram success', res);
},
fail: err => {
console.log('navigateToSmartProgram fail', err);
}
});
}
})
错误码
Android
错误码 | 说明 |
---|---|
201 |
解析失败,请检查调起协议是否合法 |
202 |
解析失败,请检查参数是否正确 |
402 |
安全性检查:访问控制校验失败 |
501 |
网络错误 |
1001 |
执行失败 |
iOS
错误码 | 说明 |
---|---|
202 |
解析失败,请检查参数是否正确 |
402 |
访问控制校验失败 |
更多建议: