跳到主要内容
版本:v8

自定义 ViewController

从 Capacitor 3.0 开始,您可以在应用程序中子类化 CAPBridgeViewController。大多数应用程序不需要此功能,但它提供了一种支持的机制来解决某些用例。

何时创建子类

需要子类化的一些示例包括在运行时覆盖 Capacitor 的配置值、更改 WKWebViewConfiguration 的属性、替换 WKWebView 的自定义子类供 Capacitor 使用、集成建议向 viewDidLoad() 添加代码的第三方 SDK、在原生视图出现在屏幕上之前操作它们,或注册自定义插件

如果您确实需要创建自定义子类,有几个步骤可以开始。

创建 MyViewController.swift

首先,通过 打开 Xcode 创建 MyViewController.swift 文件,右键单击 App 组(在 App target 下),从上下文菜单中选择 New File...,在窗口中选择 Cocoa Touch Class,在下一个屏幕中将 Subclass of: 设置为 UIViewController,然后保存文件。

在 Xcode 中创建 ViewController 在 Xcode 中命名 ViewController

编辑 Main.storyboard

接下来,在 Project Navigator 中选择 Main.storyboard 文件,在 Bridge View Controller Scene 中选择 Bridge View Controller,在右侧选择 Identity Inspector,并将自定义类的名称更改为 MyViewController

在 Xcode 中编辑 Storyboard

编辑 MyViewController.swift

最后,在 Project Navigator 中选择 MyViewController.swift 文件并编辑它以导入 Capacitor 并更改父类:

import UIKit
import Capacitor

class MyViewController: CAPBridgeViewController {
// additional code
}

您完成了!

下一步

Xcode 在生成文件时应该已经为您创建了 viewDidLoad() 方法,但请查看 CAPBridgeViewController 中的内联文档,以找到您可能需要的 Capacitor 特定方法。任何标记为 open 的方法都明确暴露给子类以进行覆盖。