Send Notification When a Property is Changed Using

2019-04-04 02:09发布

问题:

I had a property named myName in my class, like:

@property (nonatomic, strong) NSString *myName;

I need to send a notification when the myName property's value is changed.

Now I'm doing something like:

- (void)setMyName:(NSString *)name
{
  _myName = name;
  [[NSNotificationCenter defaultCenter] postNotificationName:CHANGE_NOTIFICATION object:nil];
}

I know there is something like Key-Value Observing in iOS. But I don't know how to implement it, I read the entire document, but couldn't get a good understanding.

Please help me to understand how to implement the same without using custom setter.

回答1:

Try this:

MyClass *var = [MyClass new];
[var addObserver:self forKeyPath:@"myName" options:NSKeyValueChangeOldKey context:nil];

and implement

- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context
{

}

this method will be called anytime when myName property changes



回答2:

In - (void)setMyName:(NSString *)name do this instead

[self willChangeValueForKey:@"myName"];
_myName = name;
[self didChangeValueForKey:@"myName"];

//this generates the KVO's

And where you want to listen (the viewController), there in viewDidLoad add this line:

[w addObserver:self forKeyPath:@"myName" options:NSKeyValueObservingOptionNew context:nil];

//By doing this, you register the viewController for listening to KVO.

and also implement this method:

- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context {
    if ([[change objectForKey:NSKeyValueChangeNewKey] isEqual:[NSNull null]]) {
        return;
    } else {
        //read the change dictionary, and have fun :)
    }
}

//this method is invoked, whenever the property's value is changed.



回答3:

To do this without the customer setter, just synthesize the property setter. This will create all the supporting calls to willChangeValueForKey / didChangeValueForKey.

@synthesize myName;

Then set property values with dot-syntax:

self.myName = @"Inigo Montoya"

Then the observers will receive the KVO notification automatically.

(You will need to remove the observer before you release the observed object.)