评论

H5如何跳转微信小程序?

H5跳转微信小程序

之前遇到一个需求,就是要从H5跳转到小程序里,但是微信之前一直没有提供接口做跳转,我们只能做降级方案,在要跳转小程序的地方做了一个弹窗,弹窗里面放小程序码,引导用户长按识别小程序码,然后跳转到小程序内,整个流程非常之长,转化率可想而知也是很低的。

今天刚好看到有人技术群里面问了这个问题,于是我就去看了下微信的文档,发现微信偷偷的更新的这个接口,可以让微信浏览器下的H5跳转到小程序内。

相关文档在这边:

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跳转小程序

先上才艺:

html代码如下:



  var btn = document.getElementById('launch-btn');
  btn.addEventListener('launch', function (e) {
    console.log('success');
  });
  btn.addEventListener('error', function (e) {
    console.log('fail', e.detail);
  });



username为小程序的原始id,path对应的是小程序的链接地址。之前有写过微信H5的应该会知道怎么把这段代码嵌入到之前的代码里面。

目前此功能仅开放给已认证的服务号,网页的域名要在服务号的“JS接口安全域名”下。

亲测<wx-open-launch-weapp>可以跳转到任意合法合规的小程序,是任意的小程序都能跳转!!!!这个接口真开放(不怕人干坏事?)


PS:

有个坑,官方文件说的path是/a/b/c?d=1&e=2#fg,类似的这样的链接格式,但是我自己亲测如果直接使用/a/b/c?d=1&e=2#fg这样格式的链接会报页面不存在,然后我想到了小程序那边复制链接的时候会在链接后面加上.html,于是挖槽的事情发生了,把path链接格式换成/a/b/c.html?d=1&e=2#fg这样就能正常访问,不知道是微信故意这样设计的还是bug,有待考证。

然后这个接口真的可以干好多坏事,希望大家能用正确的价值观来正确使用此接口。


微信开放标签有最低的微信版本要求,以及最低的系统版本要求。

如果开发过程中出现以下情况的,要确认一下,微信版本要求为:7.0.12及以上。 系统版本要求为:iOS 10.3及以上、Android 5.0及以上。

最后一次编辑于  2020-07-09  
点赞 35
收藏
评论

83 个评论

  • #瑞安荣哥
    #瑞安荣哥
    2020-08-04

    请问有完整代码吗?加我微信:pqr888,可以给钱

    2020-08-04
    赞同
    回复
  • 流星华少
    流星华少
    2020-08-03

    有一套完整的代码吗?

    2020-08-03
    赞同
    回复
  • 神经蛙
    神经蛙
    2020-08-03

    支持H5跳小程序&APP

    2020-08-03
    赞同
    回复 1
    • 吴奕群
      吴奕群
      2020-08-03
      对的,支持
      2020-08-03
      回复
  • 青梅煮酒
    青梅煮酒
    2020-07-29

    请问是只能跳转小程序首页吗?我改成其他地址+".html"跳转显示页面不存在

    2020-07-29
    赞同
    回复 1
    • 吴奕群
      吴奕群
      2020-07-30
      你的链接地址是什么?
      2020-07-30
      回复
  • MORNINGSTART(tiezhu)
    MORNINGSTART(tiezhu)
    2020-07-28

    A小程序内嵌的H5可以通过wx-open-launch-weapp跳转其他小程序吗?

    2020-07-28
    赞同
    回复 1
    • sunshine
      sunshine
      2021-09-16
      你好,请问实现了吗
      2021-09-16
      回复
  • 。
    2020-07-23

    你好 我配置的都已成功 但是点击跳转的时候 提示小程序加载信息超时 无法启动(4,-10005) 这个问题有遇到过吗 该如何解决

    2020-07-23
    赞同
    回复
  • 嘟嘟lei
    嘟嘟lei
    2020-07-23

    您好,有试过直接触发打开小程序事件不?不需要用户点击按钮,直接打开?

    2020-07-23
    赞同
    回复
  • CoCo
    CoCo
    2020-07-21

    我的代码如下,如果加了template标签,按钮就不能显示了(真机,开发着工具均不能显示)

    如果不加template标签,点击也没有反应。

    在公众号后台已配置好js安全域名的。

    (我是微信扫一扫测试的打开的页面)

    求救,我这个是什么问题呢?

    2020-07-21
    赞同
    回复 5
    • 默
      2020-07-22
      style放到了body里面。。。
      2020-07-22
      回复
    • CoCo
      CoCo
      2020-07-23
      问题已经解决了,原因是:公众号配置错误的问题,把服务号配置好,就能显示按钮了。
      2020-07-23
      回复
    • 包厢纣王
      包厢纣王
      2020-07-27回复CoCo
      我也遇到同样得问题了·请教一下,能详细说说您是怎么做得吗?
      2020-07-27
      回复
    • 青梅煮酒
      青梅煮酒
      2020-07-29回复CoCo
      请问公众号还有哪里需要配置,不是已经config ok 吗
      2020-07-29
      回复
    • 菱玉
      菱玉
      2020-08-25回复青梅煮酒
      同问,这个还要怎么配置啊
      2020-08-25
      回复
  • 哈罗哈皮
    哈罗哈皮
    2020-07-21

    为什么我的不行,微信版本,公众号api域名,都符合,为什么不显示?

    求解:

    https://developers.weixin.qq.com/community/develop/doc/0000a0e01a0c8829d1aa4f5295b400?jumpto=comment&commentid=0006869da38258abdbaa1fbfa510

    2020-07-21
    赞同
    回复 8
    • 吴奕群
      吴奕群
      2020-07-22
      要认证的服务号才可以
      2020-07-22
      回复
    • 哈罗哈皮
      哈罗哈皮
      2020-07-22回复吴奕群
      我想问下,用开发工具不能测试按钮显示?只能用手机测试这个功能?
      2020-07-22
      回复
    • 冯帆( ॑꒳ ॑ )
      冯帆( ॑꒳ ॑ )
      2020-08-07
      解决了吗?
      2020-08-07
      回复
    • 哈罗哈皮
      哈罗哈皮
      2020-08-10回复冯帆( ॑꒳ ॑ )
      解决了,你呢
      2020-08-10
      回复
    • 梦回🍓
      梦回🍓
      2020-08-31回复哈罗哈皮
      您好,请问你是怎么解决的呢
      2020-08-31
      回复
    查看更多(3)
  • 阳
    2020-07-20
    <wx-open-launch-weapp
    
                        id="launch-btn"
    
                        username="gh_1770c4973780"
    
                        path="/pages/index/index.html"
    
                    >
    
                        <template>
    
                            <style></style>
    
                            <button className="btn" style={{ padding: '20px', border: '2px solid #ccc' }}>打开小程序</button>
    
                        </template>
    
                    </wx-open-launch-weapp>
    


    我也出现了类似的问题,页面中按钮没有显示,sdk升级到了1.6.0,微信版本7.0.14,系统版本ios 13.3。

    已经确认是认证过的企业服务号,“JS接口安全域名”和“微信授权域名”都检查过了


    2020-07-20
    赞同
    回复 2
    • 叶梓叶叶叶叶
      叶梓叶叶叶叶
      2020-08-28
      请问,你这个问题解决了吗?
      2020-08-28
      回复
    • 阳
      2020-09-03
      2020-09-03
      回复

正在加载...

登录 后发表内容