有什么方法可以检查当前是否在手机上注册了 URL 方案......使用 javascript?
检查 javascript 是否支持 URL 方案
IT技术
javascript
iphone
safari
url-scheme
2021-01-19 21:54:45
6个回答
不是无缝的。但是有一种类似于检查弹出窗口是否被阻止的方法。
当您尝试不受支持的 URL 方案时,Safari 会警告用户它不知道如何处理它并停留在同一页面上。
所以如果你给你的应用调用一些时间来激活,比如 300 毫秒,然后做其他事情来响应该方案的不存在。
这不是最漂亮的,但它有效:
function startIThrown(){
document.location = 'ithrown://restart';
setTimeout(function(){
if(confirm('You do not seem to have iThrown installed, do you want to go download it now?')){
document.location = 'http://itunes.apple.com/WebObjects/MZStore.woa/wa/viewSoftware?id=293049283&mt=8&uo=6';
}
}, 300);
}
<a href="#" onclick="startIThrown()">Restart iThrown</a>
这是一个解决方案,当您从应用程序返回时不显示弹出窗口,它假设您已经离开超过 400 毫秒:
function startiThrown() {
document.location = appurl;
var time = (new Date()).getTime();
setTimeout(function(){
var now = (new Date()).getTime();
if((now - time)<400) {
if(confirm('You do not seem to have iThrown installed, do you want to go download it now?')){
document.location = 'http://itunes.apple.com/WebObjects/MZStore.woa/wa/viewSoftware?id=293049283&mt=8&uo=6';
}
}
}, 300);
}
我发现pagehide
事件比依赖系统时间更健壮。对于我们这些喜欢非 jQuery 的人,这里是代码片段。
var appurl = 'custom://url';
var appstore = 'https://itunes.apple.com/us/app/your-app';
var timeout;
function preventPopup() {
clearTimeout(timeout);
timeout = null;
window.removeEventListener('pagehide', preventPopup);
}
function startApp() {
window.location = appurl;
timeout = setTimeout(function(){
if(confirm('You do not seem to have the App installed, do you want to go download it now?')){
document.location = appstore;
}
}, 1000);
window.addEventListener('pagehide', preventPopup);
}
从 iOS 6.0 开始,Apple 推出了智能应用横幅,它可以满足我们大多数人的需求:
- 如果未安装该应用程序,请发送到 App Store。
- 使用 app-argument 参数打开具有特定深层链接的应用程序。
包括以下元标记:
<meta name="apple-itunes-app" content="app-id=myAppStoreID, affiliate-data=myAffiliateData, app-argument=myURL">
取自此处: Safari Web 内容指南
另一个很好的(至少在最新的浏览器版本中工作)解决方法是在短暂的超时后检查浏览器窗口是否具有焦点,这样只有当 URI 方案不起作用时,您才能向用户显示一个对话框
HTML:
<a class="uri-link" data-uri="qobuzapp://" href="#">URI</a>
Javascript(此处使用 jQuery):
var windowHasFocus;
$(window).focus(function() {
windowHasFocus = true;
}).blur(function() {
windowHasFocus = false;
});
function goToUri(uri) {
window.location = uri;
setTimeout(function(){
if (windowHasFocus) {
if (confirm('You do not seem to have Qobuz installed, do you want to go download it now?')){
window.location = 'http://www.qobuz.com';
}
}
}, 100);
}
$('a').on('click', function(){
goToUri($(this).data('uri'));
});
其它你可能感兴趣的问题