如何创建可重用的IBDesignable代码

时间:2018-09-24 03:06:44

标签: swift xcode ibdesignable

使用IBDesignable时,以下代码很常见,每次创建类时我都会重复一次,是否有避免这种重复的方法?

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()
    }
}

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

在每个类声明中重复这12行代码没有任何意义。因此,如果有避免这种重复的方法,请使用我的代码作为答案。

谢谢!

1 个答案:

答案 0 :(得分:2)

一个可能的解决方案是为这些视图创建一个公共超类。唯一的缺点是您必须为每种类型(UIViewUIButton等)创建一个超类

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() { }
}

之后,将您的可设计类设为DesignableView的子类。您只需要重写themeProp()