评论

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  
点赞 33
收藏
评论

84 个评论

  • 陈新
    陈新
    2020-07-09

    请问下,path="/pages/index/index" 和   path="/pages/index/index.html" 都显示截图效果,可能是什么原因啊?

    2020-07-09
    赞同
    回复 21
    • 吴奕群
      吴奕群
      2020-07-09
      你用的是认证过的服务号吗?
      2020-07-09
      回复
    • 陈新
      陈新
      2020-07-09回复吴奕群
      对的,认证过的服务号
      2020-07-09
      回复
    • 胡萝卜
      胡萝卜
      2020-07-09
      我和你碰到一样的问题,你的搞定了吗?
      2020-07-09
      回复
    • 胡萝卜
      胡萝卜
      2020-07-09回复胡萝卜
      我的也是认证过的服务号
      2020-07-09
      回复
    • 麻邻
      麻邻
      2020-07-09回复胡萝卜
      你的button显示在页面上了吗
      2020-07-09
      回复
    查看更多(16)
  • 才子周郎
    才子周郎
    2020-07-09

    浏览器的H5网页能 跳转 小程序吗

    2020-07-09
    赞同
    回复 2
    • 吴奕群
      吴奕群
      2020-07-09
      只有微信环境下的H5才能跳转,用的是jssdk的能力,普通浏览器没法使用jssdk的能力
      2020-07-09
      回复
    • starV
      starV
      2020-07-23回复吴奕群
      必须是认证公众号打开的H5吗,能否是在微信打开的任意H5呢
      2020-07-23
      回复
  • LDB♡
    LDB♡
    2020-07-09

    html 的内容template 宽高怎么设都是 0 显示不出按钮 这个应该怎么写?

    2020-07-09
    赞同
    回复 17
    • 陈新
      陈新
      2020-07-09
      微信版本要求为:7.0.12及以上。 系统版本要求为:iOS 10.3及以上、Android 5.0及以上。
      2020-07-09
      回复
    • 王二娃子
      王二娃子
      2020-07-09回复琪艺安
      真机上应该会显示按钮,开发者工具不显示
      2020-07-09
      回复
    • 麻邻
      麻邻
      2020-07-09
      我也不显示。。。宽高都为0
      2020-07-09
      回复
    • 2020-07-09
      openTagList和jsApiList别混淆了
      2020-07-09
      回复
    • 麻邻
      麻邻
      2020-07-09回复
      我也不知道是哪里出了问题
      2020-07-09
      回复
    查看更多(12)
  • yeah
    yeah
    2020-07-08

    啥时候小程序能跳出到h5就好了

    2020-07-08
    赞同
    回复 3
    • 吴奕群
      吴奕群
      2020-07-08
      走web-view啊
      2020-07-08
      回复
    • 会笑
      会笑
      2020-07-08
      小程序能直接跳H5了
      2020-07-08
      回复
    • yeah
      yeah
      2020-07-09回复吴奕群
      那个只是在小程序内部打开的,不是跳出小程序到内置浏览器的
      2020-07-09
      回复

正在加载...

登录 后发表内容