我需要在WKWebView中打开URL并登录到门户。用户成功登录后,我必须从WKWebView执行下载操作,一切正常,但可以在外部safari浏览器中打开,但根据要求应在WKWebView中打开
WKWebView的插座
@IBOutlet var webView: WKWebView!
在WKWebVIew中调用URL的函数
func loadURLInWebView() {
let url = URL(string: "https://www-qa.yyy.com/content/dash/en/public/login.html")
let urlRequest = URLRequest(url: url!)
if let webView = webView {
webView.load(urlRequest)
}
}
添加decisionPolicyFor委托后,它将在Safari中打开URL,但应在WKWebView中打开。我找不到问题。
public func webView(_ webView: WKWebView, decidePolicyFor navigationAction: WKNavigationAction, decisionHandler: @escaping (WKNavigationActionPolicy) -> Void) {
let url = navigationAction.request.url
guard url != nil else {
print(url!)
decisionHandler(.allow)
return
}
if url!.description.lowercased().starts(with: "http://") ||
url!.description.lowercased().starts(with: "https://") {
decisionHandler(.cancel)
UIApplication.shared.open(url!, options: [:], completionHandler: nil)
} else {
decisionHandler(.allow)
}
}
您以错误的方式处理后卫声明。在其他情况下,URL为零时将调用该条件。如果您在其他地方打印(URL!),则您的应用程序将崩溃。此外,当URL为零时,应调用cancel Handler。
public func webView(_ webView: WKWebView, decidePolicyFor navigationAction: WKNavigationAction, decisionHandler: @escaping (WKNavigationActionPolicy) -> Void) {
guard let url = navigationAction.request.url else { // else will be called when url is nil
decisionHandler(.cancel)
return
}
if url.description.lowercased().starts(with: "http://") ||
url.description.lowercased().starts(with: "https://") {
decisionHandler(.allow)
} else {
decisionHandler(.cancel)
UIApplication.shared.open(url, options: [:], completionHandler: nil)
}
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句