iOS开发进阶(十):viewController 生命周期讲解_ios开发 viewcontroller(1)

结尾

学习html5、css、javascript这些基础知识,学习的渠道很多,就不多说了,例如,一些其他的优秀博客。但是本人觉得看书也很必要,可以节省很多时间,常见的javascript的书,例如:javascript的高级程序设计,是每位前端工程师必不可少的一本书,边看边用,了解js的一些基本知识,基本上很全面了,如果有时间可以读一些,js性能相关的书籍,以及设计者模式,在实践中都会用的到。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

html5

  • viewDidLoad - 视图加载完成后调用;
  • viewWillAppear - UIViewController对象的视图即将加入窗口时调用;
  • viewDidAppear - UIViewController对象的视图已经加入窗口时调用;
  • viewWillDisappear - UIViewController对象的视图即将消失时调用;
  • viewDidDisappear - UIViewController对象的视图已经消失时调用;
  • didReceiveMemoryWarning - 出现内存警告;
  • dealloc - 视图被销毁,此次需要在initviewDidLoad中创建的对象进行释放;

初始化

  • init 方法:初始化UIViewController,执行关键数据初始化操作。不要在此操作view,view在loadView: 方法中才初始化。

加载视图

  • loadView: 方法是在UIViewController对象的view被访问且为空的时候调用,这个方法会加载或者创建一个view并将其赋值给view属性。在ViewController的生命周期中没有特殊情况只会被调用一次。
    你可以通过重写该方法来手动初始化views。在该方法的实现中,不能调用super。
  • viewDidLoad 方法:view加载完成后调用。通常,对于各种初始化数据的载入,初始设定、修改约束、移除视图等很多操作都可以这个方法中实现。通常在此方法中添加一些控件和视图。
  • viewWillAppear 方法:系统在载入所有的数据后,将会在屏幕上显示视图,这时会先调用这个方法,通常会在这个方法对即将显示的视图做进一步的设置。比如,设置设备不同方向时该如何显示;设置状态栏方向、设置视图显示样式等。
    当APP有多个视图时,上下级视图切换是也会调用这个方法,如果在调入视图时,需要对数据做更新,就只能在这个方法内实现。
  • viewDidAppear 方法:UIViewController对象的视图已经加入窗口时调用。这时可以对正在显示的视图做设置。
  • viewWillDisAppear 方法:UIViewController对象的视图即将消失、被覆盖或是隐藏时调用。
  • viewDidDisAppear 方法:UIViewController对象的视图已经消失、被覆盖或是隐藏时调用。

内存警告

  • didReceiveMemoryWarning 方法:在内存足够的情况下,app视图通常会一直保存在内存中,如果内存不够,会释放掉自己拥有的视图。系统只会释放内存,不会释放对象的所有权,通常需要在这里将不需要显示在内存中保留的对象释放它的所有权,置为nil。

视图销毁
dealloc 方法:销毁视图,释放资源。不要手动调用此方法,当引用计数值为0的时候,系统会自动调用此方法。

二、注意事项

loadViewviewDidLoad的区别就是,loadView时view还没有生成,viewDidLoad时,view已经生成了,loadView只会被调用一次,而viewDidLoad可能会被调用多次(View可能会被多次加载),当view被添加到其他view中之前,会调用viewWillAppear,之后会调用viewDidAppear。当view从其他view中移除之前,调用viewWillDisAppear,移除之后会调用viewDidDisappear。当view不再使用时,受到内存警告时,ViewController会将view释放并将其指向为nil

三、案例讲解

分为A和B两个视图。

A视图:

AViewController.h 文件:

#import <UIKit/UIKit.h>
#import "BViewController.h"
 
NS_ASSUME_NONNULL_BEGIN
 
@interface AViewController : UIViewController
 
@end
 
NS_ASSUME_NONNULL_END

AViewController.m文件:

#import "AViewController.h"
 
@interface AViewController ()
 
@end
 
@implementation AViewController
 
- (void) loadView {
    [super loadView];
 
    NSLog(@"AViewController loadView");
}
 
- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    self.view.backgroundColor = [UIColor whiteColor];
    
    UIButton\* button = [UIButton buttonWithType:UIButtonTypeRoundedRect];
    button.frame = CGRectMake(100, 100, 100, 50);
    button.center = self.view.center;
    [button setTitle:@"按键" forState:UIControlStateNormal];
    [button addTarget:self action:@selector(press:) forControlEvents:UIControlEventTouchUpInside];
    
    [self.view addSubview:button];
    
    NSLog(@"AViewController viewDidLoad");
}
 
- (void) viewWillAppear:(BOOL)animated {
    NSLog(@"AViewController viewWillAppear");
}
 
- (void) viewDidAppear:(BOOL)animated {
    NSLog(@"AViewController viewDidAppear");
}
 
- (void) viewWillDisappear:(BOOL)animated {
    NSLog(@"AViewController viewWillDisappear");
}
 
- (void) viewDidDisappear:(BOOL)animated {
    NSLog(@"AViewController viewDidDisappear");
}
 
- (void) didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    
    NSLog(@"AViewController didReceiveMemoryWarning");
}
 
- (void) press:(UIButton\*)sender {
    BViewController\* bViewController = [[BViewController alloc] init];
    
    bViewController.modalPresentationStyle = UIModalPresentationFullScreen;
    
    NSLog(@"A->B");
    
    [self presentViewController:bViewController animated:YES completion:nil];
}
 
@end

BViewController.h文件:

#import <UIKit/UIKit.h>
 
NS_ASSUME_NONNULL_BEGIN
 
@interface BViewController : UIViewController
 
@end
 
NS_ASSUME_NONNULL_END

BViewController.m文件:

#import "BViewController.h"
 
@interface BViewController ()
 
@end
 
@implementation BViewController


#### react和vue的比较

相同
1)vitual dom
2)组件化
3)props,单一数据流

不同点
1)react是jsx和模板;(jsx可以进行更多的js逻辑和操作)
2)状态管理(react)
3)对象属性(vue)
4)vue:view——medol之间双向绑定
5)vue:组件之间的通信(props,callback,emit)

>**[开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】](https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0)**

![](https://img-blog.csdnimg.cn/img_convert/4b59fdf5751a80137060f1e3299dc3be.webp?x-oss-process=image/format,png)

![](https://img-blog.csdnimg.cn/img_convert/2f04cd9ec70e830b7d225ee4bcca5af8.webp?x-oss-process=image/format,png)



>**[开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】](https://bbs.csdn.net/forums/4304bb5a486d4c3ab8389e65ecb71ac0)**

[外链图片转存中...(img-QCdfzuoZ-1715781069196)]

[外链图片转存中...(img-oNPsVyrF-1715781069196)]

  • 30
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值