如何创建可重复使用的 IBDesignable 代码

How To Create A Re-usable IBDesignable Code

使用 IBDesignable 时,以下代码很常见,我每次创建时都会重复 class,有没有办法避免这种重复?

override init(frame: CGRect) {
    super.init(frame: frame)

    themeProp()
}

required init?(coder aDecoder: NSCoder) {
    super.init(coder: aDecoder)

    themeProp()
}

override func prepareForInterfaceBuilder() {
    super.prepareForInterfaceBuilder()

    themeProp()
}

这就是我目前使用 IBDesignable 为 UIButton 创建样式的方式。

import UIKit

let colorWhite = colorLiteral(red: 0.9999127984, green: 1, blue: 0.9998814464, alpha: 1)
let colorLavender = colorLiteral(red: 0.6604440808, green: 0.5388858914, blue: 0.8827161193, alpha: 1)

@IBDesignable class PrimaryButtonA: UIButton {

    override init(frame: CGRect) {
        super.init(frame: frame)

        themeProp()
    }

    required init?(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)

        themeProp()
    }

    func themeProp() {
        setTitleColor(colorWhite, for:.normal)
        self.layer.cornerRadius = 10
        backgroundColor = colorLavender
    }

    override func prepareForInterfaceBuilder() {
        super.prepareForInterfaceBuilder()

        themeProp()
    }
}


@IBDesignable class PrimaryButtonB: UIButton {

    override init(frame: CGRect) {
        super.init(frame: frame)

        themeProp()
    }

    required init?(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)

        themeProp()
    }

    func themeProp() {
        setTitleColor(colorWhite, for:.normal)
    }

    override func prepareForInterfaceBuilder() {
        super.prepareForInterfaceBuilder()

        themeProp()
    }
}

以我有限的知识,我尝试创建一个函数并尝试在每个 class 中调用它,但它不起作用。

在每个class声明中重复这12行代码没有任何意义。所以,如果有办法避免这种重复,那么请使用我的代码作为答案。

谢谢!

一个可能的解决方案是为这些视图创建一个通用的超级class。唯一的缺点是你必须为每个类型(UIViews、UIButtons 等)创建一个 superclass

class DesignableView: UIView {
    override init(frame: CGRect) {  
        super.init(frame: frame)  
        themeProp()  
    }  

    required init?(coder aDecoder: NSCoder) {  
        super.init(coder: aDecoder)  
        themeProp()  
    }  

    override func prepareForInterfaceBuilder() {  
        super.prepareForInterfaceBuilder()  
        themeProp()  
    }

    func themeProp() { }
}

之后,使您的可设计 class 成为 DesignableView 的子class。您只需要在其中覆盖 themeProp()