gpt4 book ai didi

swift - swift 改变(精炼)委托(delegate)类型

转载 作者:搜寻专家 更新时间:2023-10-31 22:33:03 28 4
gpt4 key购买 nike

我有一个(swift)类,它有一个指向委托(delegate)的弱指针,如下所示:

import UIKit


@objc public protocol DRSlidingPanelViewControllerDelegate : class {

optional func didSlidePanel(panelHidden : Bool , sender : DRSlidingPanelViewController) -> Void

}

public class DRSlidingPanelViewController: UIViewController {

public weak var delegate : DRSlidingPanelViewControllerDelegate?

///other stuff...
}

现在我用扩展第一个协议(protocol)的另一个协议(protocol)创建了一个子类,我想改变继承的“委托(delegate)”属性

@objc public protocol  DRTableViewControllerDelegate : DRSlidingPanelViewControllerDelegate  {

optional func someFunction(sender : DRTableViewController) -> Void
}


public class DRTableViewController: DRSlidingPanelViewController {

// public weak var delegate : DRTableViewControllerDelegate?
}

^ 当我取消注释时,子类中委托(delegate)的这个(重新)声明给了我 3 个错误。

  1. 类型为“DRTableViewControllerDelegate?”的属性“委托(delegate)”? (又名“可选”)不能覆盖类型为“DRSlidingPanelViewControllerDelegate?”的属性? (又名“可选”)
  2. 使用 Objective-C 选择器“delegate”的“delegate”getter 与具有相同 Objective-C 选择器的父类(super class)“DRSlidingPanelViewController”的“delegate”getter 冲突
  3. 使用 Objective-C 选择器“setDelegate:”的“delegate” setter 与具有相同 Objective-C 选择器的父类(super class)“DRSlidingPanelViewController”中的“delegate” setter 冲突

现在我了解了这些错误的性质,并且它们是一个错误的不同方面(试图更改委托(delegate)指针上的“类型”。)任何人都可以告诉我如何执行此操作吗?显然可以做到,看看 UITableView 如何改变它从 UIScrollView 继承的委托(delegate)指针。在 objC 中,我会收到一条警告,可以使用 @dynamic 将其静音。谢谢并致以最诚挚的问候

编辑/添加谢谢马特,我确实看到了this previous question,但不幸的是它已经关闭,我个人不会接受该答案作为最终答案,因为它是一种妥协。

如果我在 xCode 中右键单击 UITableView 并“跳转到定义”,我会看到这个

@available(iOS 2.0, *)
public class UITableView : UIScrollView, NSCoding {

public init(frame: CGRect, style: UITableViewStyle) // must specify style at creation. -initWithFrame: calls this with UITableViewStylePlain
public init?(coder aDecoder: NSCoder)

public var style: UITableViewStyle { get }
weak public var dataSource: UITableViewDataSource?
**weak public var delegate: UITableViewDelegate?**

//plenty other stuff..
}

因此,我恭敬地表示,确实有办法做到这一点。

最佳答案

我会说,就目前情况而言,您无法做到。这至少可以说是令人失望的。您只需要调用子类中的委托(delegate)变量。

所以,这是合法的,但是当然完全不能满足你的要求:

@objc protocol P1 {
}
@objc protocol P2 : P1 {
}
public class VC1: UIViewController {
weak var delegate : P1?
}
public class VC2: VC1 {
weak var delegate2 : P2?
}

如果你真的讨厌存储的倍增,你可以使 delegate2 成为访问继承的 delegate 的计算变量:

@objc protocol P1 {
}
@objc protocol P2 : P1 {
}
public class VC1: UIViewController {
weak var delegate : P1?
}
public class VC2: VC1 {
weak var delegate2 : P2? {
set {
super.delegate = newValue
}
get {
return super.delegate as? P2
}
}
}

关于swift - swift 改变(精炼)委托(delegate)类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35530946/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com