iOS 中支持点击网页scheme超链接打开其他app

网页内容如图所示

思路,点击网页中一个href 超链接的时候,会执行 decidePolicyForNavigationAction 方法,我们在改方法中截获URL,

判断如果是URL scheme类型的,则执行 \[UIApplication sharedApplicationopenURL:URL options:@{} completionHandler:nil] 方法,打开URL,并取消这次加载

实现方法

复制代码
- (void)webView:(WKWebView *)webView decidePolicyForNavigationAction:(WKNavigationAction *)navigationAction decisionHandler:(void (^)(WKNavigationActionPolicy))decisionHandler
{
    NSURL *URL = navigationAction.request.URL;
    if (![URL.absoluteString hasPrefix:@"http"] ) {
        [[UIApplication sharedApplication]openURL:URL options:@{} completionHandler:nil];
        decisionHandler(WKNavigationActionPolicyCancel);
        return;

    }
    decisionHandler(WKNavigationActionPolicyAllow);
}

app配置 url sheme

目标app被打开的时候,就会执行这个方法

复制代码
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey,id> *)options{

注意点: 打开微信小程序也可以通过URL scheme 这里使用了一个测试的URL

weixin://dl/business/?t=YtqQ6kpcrQd

相关推荐
EricStone1 天前
VibeCoding工程流程学习二:iOS项目架构
ios·vibecoding
天桥吴彦祖3 天前
判断iOS如何监听手机屏幕是否锁屏
ios
敲代码的鱼4 天前
PDF 预览与签名批注写回 支持安卓 iOS 鸿蒙 UTS插件
android·前端·ios
时光足迹4 天前
uni-app 视频通话实战:康复师与患者视频问诊的 6 个致命 Bug 与解决方案
android·ios·uni-app
时光足迹4 天前
JPush UniApp UTS 插件完全参考手册:API、事件与厂商通道一网打尽
vue.js·ios·uni-app
时光足迹4 天前
极光推送全攻略(下):uni-app 代码实现与 iOS 排查实战
vue.js·ios·uni-app
时光足迹4 天前
极光推送全攻略(上):被iOS证书折磨了三天,我写了一份前端也能看懂的避坑指南
前端·ios·uni-app
编程范式5 天前
SwiftUI 中图片如何适配可用空间
ios
songgeb7 天前
启发式 UI 自动化:从线性剧本到每步读屏决策
ios·测试
壹方秘境11 天前
我用Go语言开发了一个跨平台的HTTPS抓包和调试工具
前端·后端·ios