gpt4 book ai didi

arrays - 观察数组任何成员的任何属性的变化

转载 作者:行者123 更新时间:2023-11-28 13:30:34 25 4
gpt4 key购买 nike

我有一个存储类对象的数组:

class Apple {

var color = "Red"

}

let myApple = Apple()

var apples = [Apple]()

apples.append(myApple)

// Func should be called here
myApple.color = "Blue"

let otherApple = Apple()

// Func should not be called here,
// because otherApple is not a member of apples array
otherApple.color = "Green"

我想在“apples”数组的任何成员的任何属性发生变化时运行一个函数。调用此函数时,我需要将属性更改的数组项作为参数传递。

我想过在 color 属性上使用 didSet,但在那种情况下,当 otherApple 的属性也发生变化时会调用该函数。这不是我想要的。我只想在数组成员的属性发生更改时运行该函数。如果不是成员,则该函数不应运行。

使用didSet,在任何情况下运行函数,并在函数开头检查成员资格可能是一个想法,但我觉得这不是一个好方法。

如何使用 Swift 正确实现这一目标?

编辑:Apple 的指南Using Key-Value Observing in Swift

最佳答案

您需要将 observer 添加到您要添加到 apples array 中的所有 Apple 对象.

首先在类级别创建一个类型为[NSKeyValueObservation] 的名为observers 的属性,即

var observers = [NSKeyValueObservation]()

现在,创建一个方法,将在 apples 数组 中追加新的 Apple 实例,并向其添加 observer

func addNewApple(_ apple: Apple) {
observers.append(apple.observe(\.color, options: [.new], changeHandler: { (apple, changes) in
if let newValue = changes.newValue {
print(newValue)
}
}))
apples.append(apple)
}

要观察对象的属性,必须将其标记为@objc dynamic。所以,Apple 的定义是这样的,

class Apple: NSObject {
@objc dynamic var color = "Red"
}

现在,您可以按照下面的说明使用它,

let myApple = Apple()
self.addNewApple(myApple)
myApple.color = "Blue"

结合所有的点点滴滴,整个代码可以这样写,

class VC: UIViewController {
var apples = [Apple]()
var observers = [NSKeyValueObservation]()

override func viewDidLoad() {
super.viewDidLoad()

let myApple = Apple()
self.addNewApple(myApple)
myApple.color = "Blue"

let otherApple = Apple()
otherApple.color = "Green"
}

func addNewApple(_ apple: Apple) {
observers.append(apple.observe(\.color, options: [.new], changeHandler: { (apple, changes) in
if let newValue = changes.newValue {
print(newValue)
}
}))
apples.append(apple)
}
}

关于arrays - 观察数组任何成员的任何属性的变化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57404402/

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