IOS使用WebView内嵌H5页面,使用a标签点击跳转无效问题解决

在使用WKWebView加载H5时,给文字添加超链接,使其可以点击跳转到某个地址。发现在 IOS 的app内,a标签点击跳转没有作用,无法跳转到正确地址,decidePolicyForNavigationAction也无法抓取到点击事件。但安卓是可以正常跳转。

iOS的用户长按链接也是可以打开链接的,不过是打开了个菜单,可以跳转到了浏览器。

WKWebView 加载完链接后点击内部链接无法跳转,是因为<a href = "xxx" target = "_black"> 中的target = "_black" 是打开新的页面,所以无法在当前页面打开,需要在当前页重新加载url。

a 超连接中target:

  • _blank -- 在新窗口中打开链接
  • _parent -- 在父窗体中打开链接
  • _self -- 在当前窗体打开链接,此为默认值
  • _top -- 在当前窗体打开链接,并替换当前的整个窗体(框架页)

解决方案01:

将a标签中的target="_blank"删除,或改为target="_self"

解决方案02:

给a标签添加点击事件,如:

html 复制代码
<a @click="jumpToUrl" target="_blank"  />

jumpToUrl(){
	window.location.href = this.url
}

解决方案03:

objectivec 复制代码
// WKWebView调用window.open(url, "_blank");没有反应的问题
- (WKWebView *)webView:(WKWebView *)webView createWebViewWithConfiguration:(nonnull WKWebViewConfiguration *)configuration forNavigationAction:(nonnull WKNavigationAction *)navigationAction windowFeatures:(nonnull WKWindowFeatures *)windowFeatures {
    if (!navigationAction.targetFrame.isMainFrame) {
//        这里是直接跳转
//        [webView loadRequest:navigationAction.request];
		// 以下是去浏览器中打开URL
        NSURL *url = navigationAction.request.URL;
        if (url) {
            // iOS 10及以后版本使用此方法
            UIApplication *application = [UIApplication sharedApplication];
            [application openURL:url options:@{} completionHandler:^(BOOL success) {
                if (success) {
                    // URL成功打开
                    NSLog(@"URL opened successfully");
                } else {
                    // URL打开失败,可能是URL无效或应用没有权限
                    NSLog(@"Failed to open URL");
                }
            }];
        } else {
            // URL字符串无效
            NSLog(@"Invalid URL string");
        }
    }
    return nil;
}

解决方案04:

objectivec 复制代码
- (void)webView:(WKWebView *)webView decidePolicyForNavigationAction:(WKNavigationAction *)navigationAction decisionHandler:(void (^)(WKNavigationActionPolicy))decisionHandler
{
    if (@available(iOS 11.0, *)) {
        WKHTTPCookieStore *cookieStore = webView.configuration.websiteDataStore.httpCookieStore;
        //get cookies
        //                [cookieStore getAllCookies:^(NSArray<NSHTTPCookie *> * _Nonnull cookies) {
        NSArray *cookies = [[NSHTTPCookieStorage sharedHTTPCookieStorage] cookies];
        for (id cookie in cookies) {
            [cookieStore setCookie:(NSHTTPCookie *)cookie completionHandler:nil];
        }
        //                }];
    } else {
        // Fallback on earlier versions
    }
    
    //如果是跳转一个新页面
    if (navigationAction.targetFrame == nil) {
//        这里是直接跳转
//        [webView loadRequest:navigationAction.request];
		// 以下是去浏览器中打开URL
        NSURL *url = navigationAction.request.URL;
        if (url) {
            // iOS 10及以后版本使用此方法
            UIApplication *application = [UIApplication sharedApplication];
            [application openURL:url options:@{} completionHandler:^(BOOL success) {
                if (success) {
                    // URL成功打开
                    NSLog(@"URL opened successfully");
                } else {
                    // URL打开失败,可能是URL无效或应用没有权限
                    NSLog(@"Failed to open URL");
                }
            }];
        } else {
            // URL字符串无效
            NSLog(@"Invalid URL string");
        }
    }
    decisionHandler(WKNavigationActionPolicyAllow);
}
相关推荐
Cutecat_18 小时前
视频字幕处理工具横向:提取模式 vs 编辑模式,该如何选择
android·前端·ios·语音识别
大熊猫侯佩1 天前
WWDC26 SwiftUI 进化之路:砸碎黑盒,彻底迎来开发自由!
ios·swiftui·swift
游戏开发爱好者81 天前
iPhone真机调试有哪些方法?一次定位推送权限问题时整理出来的几种方案
ide·vscode·ios·objective-c·个人开发·swift·敏捷流程
jnene1 天前
html 时间、价格筛选样式处理
前端·css·html
slongzhang_1 天前
jquery 修复怪异模式html未声明“<!DOCTYPE html>”
前端·html·jquery
IMPYLH1 天前
HTML 的 <abbr> 元素
前端·算法·html
神明不懂浪漫1 天前
【第三章】CSS(一)——基础选择器、CSS的属性
前端·css·html·css3
小小龙学IT1 天前
HTMX:让 HTML 重新成为前端核心的超轻量动态交互库
前端·html·交互
大熊猫侯佩1 天前
WWDC26 最被忽视的王炸:告别“伪并发”陷阱,Swift 6.4 的 async defer
ios·swift·编程语言
h-189-53-6712071 天前
苹果开发者账号防关联3.2f隔离环境传包提审iOS开发上架的高效隔离方案:iOSUploader工具实用解析
ios·ios上架·ios审核·苹果审核·苹果开发者账号·苹果开发者封号