WKWebView的代理方法解析

本文详细解析了WKWebView的导航代理WKNavigationDelegate和UI代理WKUIDelegate中的关键方法,包括页面加载、错误处理、用户交互以及新窗口创建等。通过这些代理方法,可以实现对WKWebView的精细控制,例如拦截URL、处理HTTP认证、处理JS弹窗以及解决新窗口打开问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.导航代理 WKNavigationDelegate    跟踪主框架导航进度和决定的方法

1.1

/**

*  在发送请求之前,决定是否跳转 (拦截url 从而达到js与oc交互的代码方法 就是这个)

*

*  @param webView          实现该代理的 webView

*  @param navigationAction 当前navigationAction 有关触发导航请求的操作的描述性信息。

*  @param decisionHandler  是否调转block

*/

- (void)webView:(WKWebView*)webView decidePolicyForNavigationAction:(WKNavigationAction*)navigationAction decisionHandler:(void(^)(WKNavigationActionPolicy))decisionHandler;

1.2

**

*  在收到响应后,决定是否跳转 

*

*  @param webView            实现该代理的webview

*  @param navigationResponse当前navigationAction 有关触发导航请求的操作的描述性信息。

*  @param decisionHandler    是否跳转block

*/

- (void)webView:(WKWebView*)webView decidePolicyForNavigationResponse:(WKNavigationResponse*)navigationResponse decisionHandler:(void(^)(WKNavigationResponsePolicy))decisionHandler;

 

 

1.3

/**

*  页面开始加载时调用

*

*  @param webView    实现该代理的webview

*  @param navigation有关触发导航请求的操作的描述性信息。

*/

- (void)webView:(WKWebView*)webView didStartProvisionalNavigation:(null_unspecifiedWKNavigation*)navigation;

1.4

/**

*  接收到服务器跳转请求之后调用

*

*  @param webView      实现该代理的webview

*  @param navigation  当前navigation

*/

- (void)webView:(WKWebView*)webView didReceiveServerRedirectForProvisionalNavigation:(null_unspecifiedWKNavigation*)navigation;

1.5

/**

*  加载失败时调用

*

*  @param webView    实现该代理的webview

*  @param navigation 当前navigation

*  @param error      错误

*/

1.6

/**

*  当内容开始返回时调用

*

*  @param webView    实现该代理的webview

*  @param navigation 当前navigation

*/

- (void)webView:(WKWebView*)webView didFailProvisionalNavigation:(null_unspecifiedWKNavigation*)navigation withError:(NSError*)error;

1.7

/** * 页面加载完成之后调用

 * *  @param webView 实现该代理的webview 

* @param navigation 当前navigation

 */

- (void)webView:(WKWebView *)webView didFinishNavigation:(null_unspecified WKNavigation *)navigation ;

 

1.8// 导航失败时会回调

- (void)webView:(WKWebView *)webView didFailNavigation:(null_unspecified WKNavigation *)navigation withError:(NSError *)error ;

1.9

/ 对于HTTPS的都会触发此代理,如果不要求验证,传默认就行

// 如果需要证书验证,与使用AFN进行HTTPS证书验证是一样的

- (void)webView:(WKWebView *)webView didReceiveAuthenticationChallenge:(NSURLAuthenticationChallenge *)challenge completionHandler:(void (^)(NSURLSessionAuthChallengeDisposition disposition,NSURLCredential *__nullable credential))completionHandler

2 WKUIDelegate UI 代理

2.1// 创建一个新的WebView(标签带有 target='_blank' 时,导致WKWebView无法加载点击后的网页的问题。)

- (WKWebView *)webView:(WKWebView *)webView createWebViewWithConfiguration:(WKWebViewConfiguration *)configuration forNavigationAction:(WKNavigationAction *)navigationAction windowFeatures:(WKWindowFeatures *)windowFeatures {

// 接口的作用是打开新窗口委托 WKFrameInfo *frameInfo = navigationAction.targetFrame;

if (![frameInfo isMainFrame]) { 

 [webView loadRequest:navigationAction.request]; 

 }

returnnil;

}

 

就是解决 跳转的时候 是 在 新窗口打开 链接 wkWebView 这边 没法跳转 用这个方法 解决 跳转问题 

2.2  9.0 系统 提供的 方法  当webView 关闭的时候 走的代理方法

- (void)webViewDidClose:(WKWebView*)webViewAPI_AVAILABLE(macosx(10.11), ios(9.0));

#if __IPHONE_OS_VERSION_MAX_ALLOWED > __IPHONE_9_0

- (void)webViewDidClose:(WKWebView *)webView {NSLog(@"%s", __FUNCTION__);

}

#endif

2.3   在JS端调用alert函数时,会触发此代理方法。  三种 alert  

可以 看下这个 链接  WKWebView JS调用alert  https://www.jianshu.com/p/4717b48f6c59

- (void)webView:(WKWebView*)webView runJavaScriptAlertPanelWithMessage:(NSString*)message initiatedByFrame:(WKFrameInfo*)frame completionHandler:(void(^)(void))completionHandler;

- (void)webView:(WKWebView*)webView runJavaScriptConfirmPanelWithMessage:(NSString*)message initiatedByFrame:(WKFrameInfo*)frame completionHandler:(void(^)(BOOLresult))completionHandler;

 (void)webView:(WKWebView*)webView runJavaScriptTextInputPanelWithPrompt:(NSString*)prompt defaultText:(nullableNSString*)defaultText initiatedByFrame:(WKFrameInfo*)frame completionHandler:(void(^)(NSString*_Nullableresult))completionHandler;

2.4确定给定元素是否应显示预览。

- (BOOL)webView:(WKWebView*)webView shouldPreviewElement:(WKPreviewElementInfo*)elementInfoAPI_AVAILABLE(ios(10.0));

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值