H5跳转微信小程序,以及遇到的bug
相关文档在这边:
https://developers.weixin.qq.com/doc/offiaccount/OA_Web_Apps/Wechat_Open_Tag.html
用的是JS-SDK的接口,需要使用到js-sdk-1.6.0的版本才有支持,https://res.wx.qq.com/open/js/jweixin-1.6.0.js
wx.config({
debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印
appId: '', // 必填,公众号的唯一标识
timestamp: , // 必填,生成签名的时间戳
nonceStr: '', // 必填,生成签名的随机串
signature: '',// 必填,签名
jsApiList: [], // 必填,需要使用的JS接口列表
openTagList: [] // 可选,需要使用的开放标签列表,例如['wx-open-launch-app']
});
在wx.config下面多了一项openTagList,开放标签列表,目前支持配置wx-open-launch-weapp,wx-open-launch-app
wx-open-launch-weapp 指H5跳转小程序
wx-open-launch-app 指H5跳转app
我们主要介绍的是wx-open-launch-weapp H5跳转小程序
<!-- 点击分享按钮 跳转到微信小程序 -->
<button class="btn_onekey">分享</button>
<!-- username为小程序的原始id path对应的是小程序的链接地址 -->
<wx-open-launch-weapp id="launch-btn" username="gh_XXXXXXX"
path="pages/index/index">
<script type="text/wxtag-template">
<style type="text/css">.btn{width: 200px; height: 100px;background-color: #07c160 !important;}</style>
<button class="btn">打开测试小程序</button>
</script>
</wx-open-launch-weapp>
<script src="https://code.jquery.com/jquery-3.4.1.min.js"></script>
<script typet="text/javascript" src="http://res.wx.qq.com/open/js/jweixin-1.6.0.js"></script>
<script>
$(function() {
$('.btn_onekey').on('click', function() {
$.ajax({
method: " ",
url: "公司后端写的 获取wx.config参数接口",
dataType: " ",
data: {
url: window.location.href,
},
success: function(res){
console.log(res);
if (res.code == 200) {
console.log(res.data.appId);
wx.config({
// 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印
debug: true,
// 必填,公众号的唯一标识
appId: res.data.appId,
// 必填,生成签名的时间戳
timestamp: res.data.timestamp,
// 必填,生成签名的随机串
nonceStr: res.data.nonceStr,
// 必填,签名
signature: res.data.signature,
// 必填,需要使用的JS接口列表
jsApiList: [],
// 可选,需要使用的开放标签列表,例如[‘wx-open-launch-weapp’]
openTagList: ["wx-open-launch-weapp"],
});
// config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中
wx.ready(function () {
var btn = document.getElementById('launch-btn');
// launch 用户点击跳转按钮并对确认弹窗进行操作后触发
btn.addEventListener('launch', function (e) {
console.log('success');
});
// error 用户点击跳转按钮后出现错误
btn.addEventListener('error', function (e) {
console.log('fail', e.detail);
});
});
wx.error(function (res) {
console.log(res,'error');
// config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名
});
wx.error(function(res) {
console.log(res);
// config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。
});
}
}
})
})
});
</script>
开发过程可能出现的情况:
微信版本要求为:7.0.12及以上。 系统版本要求为:iOS 10.3及以上、Android 5.0及以上
使用wx-open-launch-weapp h5跳转到微信小程序,ios按钮显示,安卓按钮不显示bug,解决办法如下:
jsApiList: ['chooseImage', 'previewImage'], // 必填,需要使用的JS接口列表