在 iOS 中,使用 WKWebView 进行网络请求有两种方法:使用默认的 URL 加载和使用自定义的 URL 加载。

  1. 使用默认的 URL 加载:
import UIKit
import WebKit

class ViewController: UIViewController, WKNavigationDelegate {
    var webView: WKWebView!

    override func viewDidLoad() {
        super.viewDidLoad()

        let webViewConfiguration = WKWebViewConfiguration()
        webView = WKWebView(frame: view.bounds, configuration: webViewConfiguration)
        webView.navigationDelegate = self
        view.addSubview(webView)

        if let url = URL(string: 'https://www.example.com') {
            let request = URLRequest(url: url)
            webView.load(request)
        }
    }

    // WKNavigationDelegate methods
    func webView(_ webView: WKWebView, didFinish navigation: WKNavigation!) {
        // 页面加载完成后的处理
    }

    func webView(_ webView: WKWebView, didFail navigation: WKNavigation!, withError error: Error) {
        // 页面加载失败时的处理
    }
}
  1. 使用自定义的 URL 加载:
import UIKit
import WebKit

class ViewController: UIViewController, WKNavigationDelegate {
    var webView: WKWebView!

    override func viewDidLoad() {
        super.viewDidLoad()

        let webViewConfiguration = WKWebViewConfiguration()
        webView = WKWebView(frame: view.bounds, configuration: webViewConfiguration)
        webView.navigationDelegate = self
        view.addSubview(webView)

        let urlString = 'https://www.example.com'
        let urlEncodedString = urlString.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed)
        if let url = URL(string: urlEncodedString ?? '') {
            let request = URLRequest(url: url)
            webView.load(request)
        }
    }

    // WKNavigationDelegate methods
    func webView(_ webView: WKWebView, didFinish navigation: WKNavigation!) {
        // 页面加载完成后的处理
    }

    func webView(_ webView: WKWebView, didFail navigation: WKNavigation!, withError error: Error) {
        // 页面加载失败时的处理
    }
}

这两种方法都需要在视图控制器中实现 WKNavigationDelegate 协议,并在适当的方法中处理页面加载成功和失败的情况。

iOS WKWebView 网络请求教程:两种方法详解

原文地址: https://www.cveoy.top/t/topic/qzlq 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录