如何重新加载 UIViewController
2个回答
2015-02-20 · 知道合伙人影视综艺行家
关注
展开全部
加载过程
加载第一步
- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
//根据nib文件实例化UIViewController
// 这个方法是在controller的类在IB中创建,但是通过Xcode实例化controller的时候用的.
//如果你的对象是UIViewControler的子类,那么你必须调用- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle*)nibBundleOrNil;方法去调用NIB文件初始化自身,即使那没有使用nib文件也会调用这个函数(默认 情况下init方法已经为你的做这件事情了),如果你调用这个方法,并传递的两个参数为空(nil),然后类会调用-loadView去读取一个名字和你 的UIViewController名字相同的nib文件,来初始化自身。如果没有这样的nib文件,你必须调用-setView:来设置一个 self.view。或者重载-loadView 方法
加载第二步
- (void)loadView
当view需要被展示而它却是nil时,viewController会调用该方法。不要直接调用该方法。
如果手工维护views,必须重载重写该方法
如果使用IB维护views,必须不能重载重写该方法
loadView和IB构建view
作用:在需要用程序自定义view时重新,其他情况可以不用考虑
加载第三步
- (void)viewDidLoad
//如果loadView不能生成UIViewController.view系统将会反复调用loadView及viewDidLoad方法, 并且最终调用[super loadView] 方法返回UIViewController.view
//重载重写该方法以进一步定制view
//在iPhone OS 3.0及之后的版本中,还应该重载重写viewDidUnload来释放对view的任何索引
//viewDidLoad后调用数据Model
//在视图加载后被调用,如果是在代码中创建的视图加载器,他将会在loadView方法后被调用,
//如果是从nib视图页面输出,他将会在视图设置好后后被调用。
作用:分配和载入在视图显示时所需要的数据
一般情况下,数据对象是通过配置view controller的属性来提供的,view controller需要的一些额外的数据应该通过重写viewDidLoad函数来提供。
加载第四步
- (void)viewWillAppear:(BOOL)animated;
//视图即将可见时调用。默认情况下不执行任何操作
加载第五步
- (void)viewDidAppear:(BOOL)animated;
//视图已完全过渡到屏幕上时调用
另外如果你这样写:
- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil{
self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
if (self) {
UIView *view = [[UIView alloc] initWithFrame:[UIScreen mainScreen].bounds];
self.view = view;
[view release];
// Custom initialization
NSLog(@”initWithNibName”);
}
return self;
}
那么loadView和viewDidLoad 方法将不会被调用
- (void)viewWillLayoutSubviews ;
- (void)viewDidLayoutSubviews;
加载第一步
- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
//根据nib文件实例化UIViewController
// 这个方法是在controller的类在IB中创建,但是通过Xcode实例化controller的时候用的.
//如果你的对象是UIViewControler的子类,那么你必须调用- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle*)nibBundleOrNil;方法去调用NIB文件初始化自身,即使那没有使用nib文件也会调用这个函数(默认 情况下init方法已经为你的做这件事情了),如果你调用这个方法,并传递的两个参数为空(nil),然后类会调用-loadView去读取一个名字和你 的UIViewController名字相同的nib文件,来初始化自身。如果没有这样的nib文件,你必须调用-setView:来设置一个 self.view。或者重载-loadView 方法
加载第二步
- (void)loadView
当view需要被展示而它却是nil时,viewController会调用该方法。不要直接调用该方法。
如果手工维护views,必须重载重写该方法
如果使用IB维护views,必须不能重载重写该方法
loadView和IB构建view
作用:在需要用程序自定义view时重新,其他情况可以不用考虑
加载第三步
- (void)viewDidLoad
//如果loadView不能生成UIViewController.view系统将会反复调用loadView及viewDidLoad方法, 并且最终调用[super loadView] 方法返回UIViewController.view
//重载重写该方法以进一步定制view
//在iPhone OS 3.0及之后的版本中,还应该重载重写viewDidUnload来释放对view的任何索引
//viewDidLoad后调用数据Model
//在视图加载后被调用,如果是在代码中创建的视图加载器,他将会在loadView方法后被调用,
//如果是从nib视图页面输出,他将会在视图设置好后后被调用。
作用:分配和载入在视图显示时所需要的数据
一般情况下,数据对象是通过配置view controller的属性来提供的,view controller需要的一些额外的数据应该通过重写viewDidLoad函数来提供。
加载第四步
- (void)viewWillAppear:(BOOL)animated;
//视图即将可见时调用。默认情况下不执行任何操作
加载第五步
- (void)viewDidAppear:(BOOL)animated;
//视图已完全过渡到屏幕上时调用
另外如果你这样写:
- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil{
self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
if (self) {
UIView *view = [[UIView alloc] initWithFrame:[UIScreen mainScreen].bounds];
self.view = view;
[view release];
// Custom initialization
NSLog(@”initWithNibName”);
}
return self;
}
那么loadView和viewDidLoad 方法将不会被调用
- (void)viewWillLayoutSubviews ;
- (void)viewDidLayoutSubviews;
展开全部
我想要重新加载 tabbar controller(UIViewController) 中所载的所有视图。搜索后发现得适用 setNeedsDisplay 方法,但我不能去哪里应该将其应用。任何其他的替代品也受到了欢迎
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
.....
.....
self.window = [[[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]] autorelease];
[self customToolbar];
[self.window addSubview:tabBarController.view];
[self.window makeKeyAndVisible];
return YES;
}
-(void)customToolbar
{
//Declared view controllers and their Navigation Controller
.....
//Declared tab bar items
.....
tabBarController = [[GTabBar alloc] initWithTabViewControllers:viewControllersArray tabItems:tabItemsArray initialTab:1];
}
解决方法 1:
正确的方法来执行此操作将添加任何需要刷新到某些 NSNotificationCenter 通知名称以观察员身份的 VC。一旦 VC 获取此消息,只是调用一个选择器,调用 [self setNeedsDisplay] 。
将一个 VC 添加到 NSNotificationCenter:
[[NSNotificationCenter defaultCenter] addObserver:self selector @selector(setNeedsDisplay) name:@"ViewControllerShouldReloadNotification" object:nil];
别忘了打电话给 removeObserver:self 视图控制器时被释放。
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
.....
.....
self.window = [[[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]] autorelease];
[self customToolbar];
[self.window addSubview:tabBarController.view];
[self.window makeKeyAndVisible];
return YES;
}
-(void)customToolbar
{
//Declared view controllers and their Navigation Controller
.....
//Declared tab bar items
.....
tabBarController = [[GTabBar alloc] initWithTabViewControllers:viewControllersArray tabItems:tabItemsArray initialTab:1];
}
解决方法 1:
正确的方法来执行此操作将添加任何需要刷新到某些 NSNotificationCenter 通知名称以观察员身份的 VC。一旦 VC 获取此消息,只是调用一个选择器,调用 [self setNeedsDisplay] 。
将一个 VC 添加到 NSNotificationCenter:
[[NSNotificationCenter defaultCenter] addObserver:self selector @selector(setNeedsDisplay) name:@"ViewControllerShouldReloadNotification" object:nil];
别忘了打电话给 removeObserver:self 视图控制器时被释放。
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询