微信 schema 跳转之非官方文档
发布于 4 年前 作者 ktang 4728 次浏览 来自 分享

微信“应该”是最近开放了 schema 跳转小程序 的能力,大大方便了短信、邮件、外部网页等唤起微信小程序。

schema 链接格式大体是这样:weixin://dl/business/?ticket=l69894d682fa8dbafe724a0ca3950741e,但是这段文本在安卓端无法识别。小规模测试结果如下:

后来想到用一个正常能够识别的网页地址,内容是重定向到指定的 schema 链接。这就是擅长的领域了,query 参数上带上 schema 链接,location.href 一下不就行了。这里就不 show 代码了,能看到文章的你一定行。

但是,发现在部分安卓手机下(如小米)还是没反应,原来简单的 schema 跳转水这么深的,于是百度谷歌了一下,找到了下面两份关键材料:

看源码也不多,总结下来,因不同系统和浏览器对 schema 规范的理解不同,还有一些商业因素,不同环境下面需要用不同的方式进行跳转,甚至有的环境你根本就跳不了

时间紧,任务重。简单处理吧,不同方式都来一遍,谁好使就用谁。所以简单总结了下,能用的几种方式:

  • location 跳转
  • a 链接跳转
  • iframe 跳转

以上三种方式,逐一试用,最后实在不行就不行吧,简单处理,看有没有大神补充的。

相关代码如下:

  • location
location.href = "weixin://dl/business/?ticket=l69894d682fa8dbafe724a0ca3950741e";
  • a 链接跳转
var aLink = document.createElement("a");
aLink.className = 'call_up_a_link';
aLink.href = "weixin://dl/business/?ticket=l69894d682fa8dbafe724a0ca3950741e";
aLink.style.cssText = "display:none;width:0px;height:0px;";
document.body.appendChild(aLink);
aLink.click();
  • iframe
var iframe = document.createElement('iframe');
iframe.className = 'call_up_iframe';
iframe.src = "weixin://dl/business/?ticket=l69894d682fa8dbafe724a0ca3950741e";
iframe.style.cssText = "display:none;width:0px;height:0px;";
document.body.appendChild(iframe);

以上代码均可从参考资料中找到出处,感谢

是直接一进来就执行,还是事件触发,都可以。或者是一开始进来就执行,失败了显示几个可选跳转按钮让用户手动触发跳转。

但是关键问题还有一个,如何判断是可以成功唤起了呢?上述 github 代码里提到了一个根据页面 hidden 状态,但不够精准,如果用户没有选择跳转到微信呢?这是另一个需要深究的问题。

出于时间考虑,先以业务交付优先,如果有朋友知道的也可以一起讨论下。

另行文时间短,以技术交流为主,若有瑕疵,欢迎指出。

附上 vue 版本源码:微信 schema 跳转


参考链接:

5 回复

没很清楚搞懂

很棒,正好需要

每个小程序每天1000条的限制,达到了会怎么样呢

业内标准的杂乱真实苦了开发人员啦 ,楼主分享的不错,点赞。

回到顶部