评论

H5跳转微信小程序,以及遇到的bug

开发中遇到的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接口列表
最后一次编辑于  2021-04-10  
点赞 3
收藏
评论

11 个评论

  • Estelle
    Estelle
    2021-09-06

    请问这个h5可以打开小程序吗

    2021-09-06
    赞同
    回复 1
    • 🍓泡芙卷
      🍓泡芙卷
      2021-10-14
      H5跳转到小程序
      2021-10-14
      回复
  • 幸福眼泪
    幸福眼泪
    2021-08-20

    我加了,也不显示出来。头大了

    2021-08-20
    赞同
    回复
  • 小🌙儿尖
    小🌙儿尖
    2021-08-02

    使用wx-open-launch-weapp 时,必须填写的jsApiList官方可否明确下?

    2021-08-02
    赞同
    回复 1
    • 本白非白
      本白非白
      2021-09-12
      'startRecord',
                              'stopRecord',
                              'onVoiceRecordEnd',
                              'playVoice',
                              'pauseVoice',
                              'stopVoice',
                              'onVoicePlayEnd',
                              'translateVoice',
                              'onMenuShareTimeline',

                              'wx-open-launch-weapp'
      我用的是这几个,也是抄别人的,但是可以跳转打开
      2021-09-12
      回复
  • Pulse.
    Pulse.
    2021-06-29

    wx-open-launch-weapp 微信电脑端不显示跳转按钮 ,移动端可以正常显示,这个问题现在有解决办法吗

    2021-06-29
    赞同
    回复 1
    • 小宇
      小宇
      2021-10-30
      您好请问解决了吗,我也碰到了
      2021-10-30
      回复
  • Kai秀
    Kai秀
    2021-06-13

    有源码吗?


    2021-06-13
    赞同
    回复
  • bing
    bing
    2021-06-03

    赞,刚好遇到android用开放标签无效的问题

    2021-06-03
    赞同
    回复
  • 瓜瓜
    瓜瓜
    2021-06-02

    还没试 但是超赞

    2021-06-02
    赞同
    回复
  • 天上月
    天上月
    2021-05-19

    不使用企业微信App,而是在微信里面的企业号H5应用页面,能否跳转到小程序

    2021-05-19
    赞同
    回复
  • ꧁꫞꯭豆角꯭꫞꧂
    ꧁꫞꯭豆角꯭꫞꧂
    2021-05-10

    弹框是隐藏的, 我的wx-open-launch-weapp 是在弹框里面显示不出来 ,需要动态设置display:block ,才可以


    2021-05-10
    赞同
    回复 1
    • 勠力同心
      勠力同心
      2021-12-03
      请问您的问题解决了吗?我这按钮显示不出来,能帮忙看一下原因吗?
      2021-12-03
      回复
  • 一
    2021-04-14
    请问获取wx.config参数接口必须要有吗? 我参照文档里给的试例随便添了一些, wx.config({
                            debug: true, // 调试时可开启
                            appId: 'xxxx', // <!-- replace -->
                            timestamp: 0, // 必填,填任意数字即可
                            nonceStr: 'nonceStr', // 必填,填任意非空字符串即可
                            signature: 'signature', // 必填,填任意非空字符串即可
                            jsApiList: ['onMenuShareTimeline'], // 必填,随意一个接口即可 
                            openTagList:['wx-open-launch-weapp'], // 填入打开小程序的开放标签名
                        })      
    


    wx.ready就掉用了,但是我的按钮一直显示不出来
    


    2021-04-14
    赞同
    回复 1
    • TgLee
      TgLee
      2022-07-01
      你是云开发的静态H5调用小程序吗
      2022-07-01
      回复

正在加载...

登录 后发表内容