微信“应该”是最近开放了 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 跳转
参考链接:
请问,如果我想要跳转第三方的小程序,是否做得到呢?是否需要对方提供什么东西?
你好,我想问一下,为什么官方的demo在小米浏览器上可以直接弹出是否跳转
https://postpay-2g5hm2oxbbb721a4-1258211818.tcloudbaseapp.com/jump-mp.html
但是我自己写的就不会触发,要手动点按钮才行。
这里面是有其他的触发操作么。html源码没看出特别的地方
每个小程序每天1000条的限制,达到了会怎么样呢
https://developers.weixin.qq.com/miniprogram/dev/api-backend/open-api/url-scheme/urlscheme.generate.html。简单说来就是微信提供了一种从 schema 链接打开小程序的方式,但是因为不同系统对 schema 支持的不是很友好,所以有了这篇文章。