我是故事板的新手,我已经设置了一个从一个按钮到一个视图控制器.该视图控制器是一个自定义子类SFListViewController,它具有指定的初始化器initWithList :.
使用指定的初始化程序是正确初始化视图控制器的唯一方法.然而,当使用segue时,将不会调用指定的初始化程序(显然).
- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender { if ([segue.identifier isEqualToString:@"Show List"]) { SFListViewController *listViewController = segue.destinationViewController; // ???? } }
执行时如何使segue调用指定的初始化程序?
解决方法
据我所知,这是不可能的,因为故事板框架简单地在您在Interfacebuilder中定义的类中调用alloc和init.另外,segue的destinationViewController属性是只读的,所以你不能简单地替换现有的ViewController.
使用Storyboarding的唯一方法可能是创建一个包装类,内部实例化具有所需属性的SFListViewController,然后作为代理对象,从而将viewDid ***和viewWill ***方法传播到包装类,也将包装的VC的视图以只读视图属性返回…你会得到想法.
在这种情况下,通常有许多替代方法初始化UIViewController:
>有一个选项来指定可以用于初始化的“用户定义的运行时属性”.
>覆盖prepareForSegue:方法,就像您尝试的那样,在您的根ViewController中,并在其中执行“post-alloc-init-initialisation”.
>如果最坏的情况是最坏的,你可以回到IBAction,以便能够自己初始化ViewController.
我希望这有帮助.
编辑:我可以验证代理方法是否有效,因为我刚刚遇到与ABPeoplePickerNavigationController类似的问题,这种方法工作得很好.因为我们在我们的故事板中设置了这个事情,请注意,为了进行初始配置(而不是一些init方法),你必须使用awakeFromNib.
这是我的包装类的代码:
#import "PeoplePickerViewControllerWrapper.h" @implementation PeoplePickerViewControllerWrapper @synthesize ppvc = _ppvc; // This is the object I'm proxying (The proxyee so to speak) @synthesize delegate = _delegate; - (void)awakeFromNib { self.ppvc = [[ABPeoplePickerNavigationController alloc] init ]; self.ppvc.peoplePickerDelegate = self; self.ppvc.addressBook = ABAddressBookCreate(); self.ppvc.displayedProperties = [NSArray arrayWithObject:[NSNumber numberWithInt:kABPersonPhoneProperty]]; } #pragma mark - View lifecycle - (void)loadView { [super loadView]; [self.ppvc loadView]; } - (void)viewDidLoad { [super viewDidLoad]; [self.ppvc viewDidLoad]; } -(void)viewWillAppear:(BOOL)animated{ [super viewWillAppear:animated]; [self.ppvc viewWillAppear:animated]; } -(void)viewDidDisappear:(BOOL)animated{ [super viewDidDisappear:animated]; [self.ppvc viewDidDisappear:animated]; } -(UIView *)view{ return self.ppvc.view; } - (void)viewDidUnload { [super viewDidUnload]; [self.ppvc viewDidUnload]; }