欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 财经 > 金融 > web 唤起 app 的原理

web 唤起 app 的原理

2024/10/24 15:15:27 来源:https://blog.csdn.net/zhuanyemanong/article/details/140918686  浏览:    关键词:web 唤起 app 的原理

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 请看 👉 在线效果预览, 查看示例代码请点击此处

本文首发于个人博客前端开发笔记,由于笔者能力有限,文章难免有疏漏之处,欢迎指正

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com