也许我误解了委托模式,但有人可以解释一下,当我只定义一个协议和委托属性时,如何从一个单独的委托调用委托调用?
运行下面的代码只会调用detail2VC中的doSomething,但我想在两者中都有消息。我可以定义符合协议的第二个属性,或者定义第二个协议,但我认为这不是正确的方法。
ViewController.h
#import <UIKit/UIKit.h>
@protocol ViewControllerDelegate <NSObject>
@optional
- (void)doSomething;
@end
@interface ViewController : UIViewController
@property (nonatomic, weak) id <ViewControllerDelegate> delegate;
@end
ViewController.m
#import "ViewController.h"
#import "Detail1VC.h"
#import "Detail2VC.h"
@interface ViewController ()
@end
@implementation ViewController
- (void)viewDidAppear:(BOOL)animated
{
[super viewDidAppear:animated];
if ([self.delegate respondsToSelector:@selector(doSomething)]) {
[self.delegate doSomething];
}
}
- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender
{
if ([segue.identifier isEqualToString:@"d1"]) {
self.delegate = (Detail1VC *)segue.destinationViewController;
}
if ([segue.identifier isEqualToString:@"d2"]) {
self.delegate = (Detail2VC *)segue.destinationViewController;
}
}
@end
Detail1VC.h
#import <UIKit/UIKit.h>
#import "ViewController.h"
@interface Detail1VC : UIViewController <ViewControllerDelegate>
@end
Detail1VC.m
#import "Detail1VC.h"
@interface Detail1VC ()
@end
@implementation Detail1VC
- (void)doSomething
{
NSLog(@"detail1 done");
}
@end
Detail2.VC与Detail1.VC
相同答案 0 :(得分:3)
只有一个代表集合,而不只是一个。当然,所有这些都应符合相同的协议。
在您的主实例中,您只需遍历代理集合(NSSet或NSArray)并调用协议中声明的方法。
没有规定禁止这样做。
当然,您也可以考虑其他模式是否更适合观察者,或者为什么不简单地使用NSNotificationCenter。
没有什么是坏的,只需选择最适合你的东西。
答案 1 :(得分:1)
使用最佳实践,只使用一个委托,并在声明协议的类之外动态更改它。代码审阅者可能会讨厌NSArray
代表的方式,或者如果您与团队合作,可能会误导其他开发人员。
最好的方法是使用NSNotification
通知多个对象有关事件。继续使用其他objective-c
开发人员熟悉的最佳代码。