我有一个名为Dashboard(D)的VC,它可以打开一个名为Login(L)的VC和一个名为Register(R)的VC。登录也可以打开VC Register。
我尝试尽可能多地使用故事板,所以我创建了三个Segues,D到L,D到R,L到R
因此,在D - >的情况下; L - > R和在D - >的情况下; R,当我关闭R时,我必须在必要时关闭L并通知D他可以开始加载用户信息(简言之,启动功能)。
所以,我想在目标vc中获取Segue的发送者,知道我把它放在performSegueWithIdentifier的发送者中,就像那样:
[self performSegueWithIdentifier:@"SegueToFbRegister" sender:self];
答案 0 :(得分:8)
我这样做是让R在注册/登录完成后发送通知,让D听取然后弹出所有内容并加载你的数据。
但是,如果您坚持要获取对发件人的引用,则可以在目标VC上添加此属性,并将其设置在源VC的prepareForSegue:sender:
答案 1 :(得分:8)
这听起来像是一个使用代表的好地方。在RegisterViewController.h中定义一个像这样的协议
@protocol RegisterViewDelegate <NSObject>
- (void)tellRegisterDelegateSomething:(NSObject*)something;
@end
然后在你的班级上保留一个指向你的代表的指针
@interface RegisterViewController : UIViewController
@property (weak, nonatomic) id <RegisterViewDelegate> delegate;
@end
现在告诉显示视图控制器他们实现刚刚创建的新协议。这是在显示此视图的其他视图控制器的.h文件中完成的。
在LoginViewController.h中
@interface LoginViewController : UIViewController <RegisterViewDelegate>
@end
在DashboardViewController.h中
@interface DashboardViewController : UIViewController <RegisterViewDelegate>
@end
在上述类的.m文件中,实现协议的方法
- (void)tellRegisterDelegateSomething:(NSObject*)something
{
}
现在,您需要在从这样的视图控制器执行segue时分配代理。
- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender
{
if ([[segue identifier] isEqualToString:@"SegueToFbRegister"])
{
RegisterViewController* destination = [segue destinationViewController];
destination.delegate = self;
}
}
现在你可以调用呈现视图控制器(委托)并让它对你需要发送回来的任何信息做一些事情(这将在你的RegisterViewController.m中调用)。
if ([self.delegate respondsToSelector:@selector(tellRegisterDelegateSomething:)])
{
// Tell the delegate something.
[self.delegate tellRegisterDelegateSomething:something];
}
您需要通过两个控制器传回的实例,您遵循相同的基本模式。
@protocol LoginViewDelegate <NSObject>
- (void)tellLoginDelegateSomething:(NSObject*)something;
@end
然后在你的班级上保留一个指向你的代表的指针
@interface LoginViewController : UIViewController
@property (weak, nonatomic) id <LoginViewDelegate> delegate;
@end
现在告诉Dashboard视图控制器它实现了协议。这是在显示此视图的仪表板视图控制器的.h文件中完成的。
在DashboardViewController.h中
@interface DashboardViewController : UIViewController <RegisterViewDelegate, LoginViewDelegate>
@end
在DashboardViewController的.m文件中实现协议的方法
执行segue时,请遵循上面在viewcontroller上设置委托的模式。现在,当在LoginViewController中调用委托方法时,您也可以在DashboardViewController中调用委托。
在LoginViewController.m中
- (void)tellRegisterDelegateSomething:(NSObject*)something
{
if ([self.delegate respondsToSelector:@selector(tellLoginDelegateSomething:)])
{
// Tell the delegate something.
[self.delegate tellLoginDelegateSomething:something];
}
}
现在您已全部连接,因此您可以通过两个控制器(或仅一个)传递数据并对其执行某些操作。您将知道您所处的场景,因为将根据哪个viewcontroller可见,在DashboardViewController中调用不同的委托方法。
希望这有帮助。
答案 2 :(得分:0)
为 R 创建委托,并使 D 和 L 实现委托方法。使用prepareForSegue:sender
分配委托 R 。当您在 R 中完成任务时,请使用您的代理执行所需的操作。
答案 3 :(得分:0)
另一种方法是使用展开segue。
将以下代码放入 Dashboard ( D )视图控制器中。
@IBAction func loadUserInfoAfterRegistration(segue: UIStoryboardSegue) {
}
在Interface Builder中,对注册( R )视图控制器执行以下步骤:
loadUserInfoAfterRegistrationWithSegue:
。使用此方法,注册( R )视图控制器将始终导航到仪表板( D )查看控制器,无论它们之间是什么。它们之间的视图控制器不必触及。 仪表板( D )视图控制器中的用户数据加载也可以使用上面声明的方法进行自定义。