在Swift中实现变量属性属性observer

时间:2015-03-04 15:03:00

标签: swift attributes didset

我想在变量的“子属性”上实现didSet

示例:

@IBOutlet weak var myLabel: UILabel!
var myLabel.hidden { didSet{ "DO SOMETHING" } }

我希望在myLabel.hidden属性更改时隐藏/显示其他一些视图。 我该怎么办?

3 个答案:

答案 0 :(得分:3)

你可以制作这样的房产

    var hideLabel: Bool = false {
    didSet {
        myLabel.isHidden = hideLabel
        //SHOW OR HIDE OTHER VIEWS
    }
}

通过这样做,您不必在使用KVO的同时添加更多控件来隐藏以显示在didSet上下文中。 我相信这是一种更简单的方法来做这件事。

答案 1 :(得分:2)

标准流程是使用KVO。加载视图时添加观察者:

override func viewDidLoad() {
    super.viewDidLoad()

    label.addObserver(self, forKeyPath: "hidden", options: .New | .Old, context: nil)
}

取消分配视图控制器时,请务必删除观察者。

deinit {
    label.removeObserver(self, forKeyPath: "hidden")
}

observeValueForKeyPath方法中做任何你想做的事情:

override func observeValueForKeyPath(keyPath: String, ofObject object: AnyObject, change: [NSObject : AnyObject], context: UnsafeMutablePointer<Void>) {
    NSLog("\(change)")

    // do whatever you want here
}

答案 2 :(得分:1)

属性观察者只能添加到类中,而不能添加到实例中。为此,您需要继承UILabel,然后覆盖hidden的属性观察者。

编辑:如果要在CustomLabel的实例上设置自定义观察者,可以通过向didSetwillSet上触发的CustomLabel添加块函数变量来轻松完成此操作

class CustomLabel: UILabel {

    var onDidSetHidden: ((Bool) -> ())?
    var onWillSetHidden: ((Bool) -> ())?

    override var hidden: Bool {
        didSet {
            if let block = onDidSetHidden {
                block(self.hidden)
            }
        }

        willSet (willBeHidden) {
            if let block = onWillSetHidden {
                block(willBeHidden)
            }
        }
    }
}

var custom = CustomLabel()
custom.onDidSetHidden = { (isHidden) in
    if isHidden {
        println("IS HIDDEN")
    } else {
        println("IS NOT HIDDEN")
    }
}

custom.hidden = true //prints 'IS HIDDEN'