SwiftUI-WebView 全面指南

介绍

在 iOS 开发中,网页内容展示几乎是每个 App 的刚需场景。无论是展示帮助中心、隐私政策,还是嵌入在线课程、文档预览等,WebView 都扮演着重要角色。SwiftUI 7.0 通过 WebKit 模块,可以轻松实现网页加载、导航控制以及 JavaScript 交互功能。本文将从基础到高级,循序渐进介绍 SwiftUI 中的 WebView 用法。

网页加载

  • 在使用 WebView 前,需要先导入 WebKit 模块。
  • 借助 URL 或者 WebPage,可以实现网页加载与状态管理功能。

直接加载URL

swift 复制代码
import SwiftUI
import WebKit

struct ContentView: View {
    let url = URL(string: "https://www.apple.com.cn")!

    var body: some View {
        WebView(url: url)
    }
}

使用WebPage

WebPage 是一个功能更强的类型,它不仅能加载网页,还能实时监控网页的标题、加载进度、URL 状态等信息。

基本用法

swift 复制代码
import SwiftUI
import WebKit

struct ContentView: View {
    @State private var webPage = WebPage()
    let url = URL(string: "https://www.apple.com.cn")!

    var body: some View {
        WebView(webPage)
            .ignoresSafeArea()
            .onAppear {
                webPage.load(URLRequest(url: url))
            }
    }
}

内容控制

swift 复制代码
import SwiftUI
import WebKit

struct ContentView: View {
    @State private var webPage = WebPage()
    let url = URL(string: "https://www.apple.com.cn")!

    var body: some View {
        VStack {
            // 标题
            Text(webPage.title)
            // 进度
            ProgressView("", value: webPage.estimatedProgress, total: 1.0)
            // 内容
            WebView(webPage)
                .ignoresSafeArea()
                .onAppear {
                    webPage.load(URLRequest(url: url))
                }
        }
    }
}

高级控制

导航策略

如果需要在网页跳转时进行判断(例如拦截某些 URL、仅允许访问特定域名),可以自定义导航策略。

swift 复制代码
import SwiftUI
import WebKit

// 导航处理方式
struct NavigationDecider: WebPage.NavigationDeciding {
    func decidePolicy(for response: WebPage.NavigationResponse) async -> WKNavigationResponsePolicy {
        if response.response.url?.absoluteString.starts(with: "https://www.apple.com") == true {
            .allow
        } else {
            .cancel
        }
    }
}

struct ContentView: View {
    @State private var webPage: WebPage = {
        var config = WebPage.Configuration()
        config.applicationNameForUserAgent = "User Agent"
        return WebPage(configuration: config, navigationDecider: NavigationDecider())
    }()
    let url = URL(string: "https://www.baidu.com")!

    var body: some View {
        VStack {
            Text(webPage.title)
            
            ProgressView("", value: webPage.estimatedProgress, total: 1.0)

            WebView(webPage)
                .ignoresSafeArea()
                .onAppear {
                    webPage.load(URLRequest(url: url))
                }
        }
    }
}

JavaScript 交互

许多场景需要与网页内部的 JavaScript 进行交互,如调用函数、获取返回值等。SwiftUI 也提供了非常方便的异步调用方式。

代码

swift 复制代码
import SwiftUI
import WebKit

struct ContentView: View {
    @State private var webPage = WebPage()
    @State private var title = ""
    let url = URL(string: "https://www.apple.com.cn")!

    var body: some View {
        VStack {
            title.isEmpty ? Text(webPage.title) : Text(title)

            ProgressView("", value: webPage.estimatedProgress, total: 1.0)

            WebView(webPage)
                .ignoresSafeArea()
                .onAppear {
                    webPage.load(URLRequest(url: url))
                }
                .task {
                    try? await Task.sleep(for: .seconds(3), clock: .suspending)
                    let jsResult = try? await webPage.callJavaScript(
                        """
                        console.log("Hello SwiftUI")
                        return "JavaScript Returned Value"
                        """
                    )
                    title = jsResult as! String
                }
        }
    }
}

效果

相关推荐
2501_916008892 小时前
全面介绍Fiddler、Wireshark、HttpWatch、SmartSniff和firebug抓包工具功能与使用
android·ios·小程序·https·uni-app·iphone·webview
Haha_bj6 小时前
Flutter ——flutter_screenutil 屏幕适配
android·ios
Haha_bj6 小时前
Flutter ——device_info_plus详解
android·flutter·ios
山水域11 小时前
SKAdNetwork 6.0 深度实战:多窗口转化值(Conversion Value)建模与数据分层架构
ios
JavinLu12 小时前
ios 配置了代理且使用 chls.pro/ssl 下载不了证书,无法弹出下载证书的提示问题
网络协议·ios·ssl
G311354227314 小时前
免费苹果 Plist 文件在线制作 iOS IPA 安装工具
ios
2401_8322981015 小时前
免费p12证书在线检测iOS苹果证书状态一键查询
ios
符哥200816 小时前
Swift 开发 iOS App 过程中写自定义控件的归纳总结
ios·cocoa·swift
pop_xiaoli16 小时前
effective-Objective-C 第二章阅读笔记
笔记·学习·ios·objective-c·cocoa
未来侦察班1 天前
一晃13年过去了,苹果的Airdrop依然很坚挺。
macos·ios·苹果vision pro