Swift addTarget 到按钮并调用来自 UIview 文件的不同 View Controller 文件中的函数

Swift addTarget to a button and call function in different View Controller file from UIview file

现在我在我的 Swift 项目中练习应用 MVC 模式。 我有一个 View Controller (VC) 文件和一个 UIView 文件。

在 VC 文件中,我添加了如下所示的 UIView 文件。

class MyViewController: UIViewController {
    private var myView = MyView()

    override func viewDidLoad() {
        super.viewDidLoad()
        view.addSubview(myView)
        myView.frame = CGRect(origin: .zero, size: view.bounds.size)
        // and other codes...
    }

    @objc func showDeleteAlert() {
        print("showDelete is pressed")
    }
}

然后,在 UIView 文件中,我添加了一些视图和按钮(我只是复制了按钮部分)。

class MyView: UIView {
    lazy var deleteButton: UIButton = {
        let button = UIButton()
        button.setTitle("delete", for: .normal)
        button.addTarget(target: MyViewController, action: #selector(showDeleteAlert), for: UIControl.Event.touchUpInside) // -> I get error in here saying "Cannot find 'showDeleteAlert' in scope"

        return button
    }()

// and more codes...
}

我这里想做的是如何在按下deleteButton时设置目标为showDeleteAlert函数?

我看到教程将“self”添加为目标参数,但在我的例子中,我将视图和控制器分开,所以不太确定如何访问 MyViewController 中的函数。

谢谢...

这里有两个选择:

  1. addTarget 移动到视图控制器中 viewDidLoad:
myView.deleteButton.addTarget(self, action: #selector(showDeleteAlert), for: UIControl.Event.touchUpInside)
  1. 如果您想将按钮设为私有(这是一个好习惯),您可以将代理功能添加到您的 MyView
func addDeleteButtonTarget(_ target: Any?, action: Selector) {
    deleteButton.addTarget(target, action: action, for: .touchUpInside)
}

并称它为:

myView.addDeleteButtonTarget(self, action: #selector(showDeleteAlert))

在任何情况下,您都不能调用 button.addTarget(target: MyViewController, ...),因为您需要传递 MyViewController 的实例,而不仅仅是 class 名称。