web 唤起 app 的原理
Web 唤起 App 的基本原理通常有使用定制的 URL schemes 或者 Universal Links(iOS)和 Deep Links(Android)
URL Schemes(URL 方案)
对于 iOS 和 Android 都适用。每个应用程序都可以注册一个特定的 URL 方案,类似于"myapp://"。 当用户点击 Web 页面上的链接,链接中包含了注册应用的 URL 方案,操作系统会尝试打开相应的应用程序。
例如,一个链接可能是 myapp://openPage?id=123,点击后系统会尝试打开注册了“myapp”方案的应用,并传递相应的参数。
Universal Links(iOS)
这是苹果引入的一种机制,它允许开发者在应用和网站之间建立智能链接。对应用进行配置后,点击链接时,系统会检查是否有相应的应用,如果有,就会直接打开应用而不是在浏览器中打开。
这种方式更智能,因为系统会决定是在浏览器中打开还是直接调用应用。
Deep Links(Android)
Android 上的深度链接类似于 URL 方案,但更强大。它可以通过 URI 打开应用的特定页面,而不仅仅是启动应用。例如,链接可能是 myapp://openPage?id=123,而不仅仅是启动应用。
前端实现
使用 iframe 打开 app 的方式,如果打开成功,会触发 window.blur 事件,如果打开失败,不会触发 blur 事件。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>唤起ZOOM或者TEAMS app</title>
</head>
<body>
<button id="btn1">唤起zoom(msteams://)</button>
<button id="btn2">唤起teams(zoommtg://zoom.us)</button>
<script>
document.querySelector("#btn1").addEventListener("click", () => {
const urlSchemaOfTeams = "msteams://";
appLauncher(urlSchemaOfTeams);
});
document.querySelector("#btn2").addEventListener("click", () => {
const urlSchemaOfZoom = "zoommtg://zoom.us";
appLauncher(urlSchemaOfZoom);
});
function appLauncher(protocalUrl) {
openUriWithHiddenFrame(
protocalUrl,
() => {
// 浏览器弹窗提示
alert("检测到已安装了客户端");
},
() => {
alert("检测到未安装客户端");
}
);
function _registerEvent(target, eventType, cb) {
if (target.addEventListener) {
target.addEventListener(eventType, cb);
return {
remove: function () {
target.removeEventListener(eventType, cb);
},
};
} else {
target.attachEvent(eventType, cb);
return {
remove: function () {
target.detachEvent(eventType, cb);
},
};
}
}
function _createHiddenIframe(target, uri) {
var iframe = document.createElement("iframe");
iframe.src = uri;
iframe.id = "hiddenIframe";
iframe.style.display = "none";
target.appendChild(iframe);
return iframe;
}
function openUriWithHiddenFrame(uri, successCb, failCb) {
var timeout = setTimeout(function () {
failCb();
handler.remove();
}, 1000);
var iframe = document.querySelector("#hiddenIframe");
if (!iframe) {
iframe = _createHiddenIframe(document.body, "about:blank");
}
var handler = _registerEvent(window, "blur", onBlur);
function onBlur() {
clearTimeout(timeout);
handler.remove();
successCb();
}
iframe.contentWindow.location.href = uri;
}
}
</script>
</body>
</html>
完整的 demo 请看 👉 在线效果预览, 查看示例代码请点击此处
本文首发于个人博客前端开发笔记,由于笔者能力有限,文章难免有疏漏之处,欢迎指正