微信“应该”是最近开放了 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 跳转
参考链接: