CS193p|CS193p 斯坦福IOS开发 2011 (八)
这节课主要讲ViewController 生命周期
如何创建ViewController
- 通过 一个segue或故事版的 instantiateViewControllerWithIdentifer:实例化。
一般情况不要自己定义UIViewController的初始化方法。
awakeFromNib 可选的,awakeFromNib是view的方法,有很多方法可以替代awakeFromNib放置。
awakeFromNib很早期就被调用了,那时候outlet还没连起来。那时候viewController还没完全构建完毕,不过可能有一些事情比如设置 split view delegate需要在非常早的时间完成。
- (void)viewDidLoad;
在实例化和outlet-setting后, viewDidload被调用。
在viewController已经构建完毕,只是没显示出来。
可以放置大部分的初始化的代码,
但是不能放置关于设置view大小的代码。view 是controller的一个property,是指在视图中最顶层的矩形区域,是你在故事版中编辑的最顶层的那个东西。
view的尺寸放在下个方法。
- (void)viewWillAppear:(BOOL)animated;
在view准备要显示的时候调用。
另外一个合适在viewWillAppear里做的就是 laziy do stuff 缓式动作。比如lazy init.
viewWillAppear是做那些很费资源的事情的地方
不过太费时的 话就得开启新线程来搞。
总之 viewWillAppear适合做两件事:1.最后时刻延时加载高开销的操作,2.改变view的几何特性。 - (void)viewWillDisappear:(BOOL)animated
当你的视图将要在屏幕上消失的时候调用
可以在这里记录你view的状态,数据。一般要写到磁盘里,下次进来的时候 - (void)viewWillDisappear:(BOOL)animated
{
[super viewWillDisappear:animated]; // 这个要写
[self rememberScrollPosition]; // 记住滚动的位置
[self saveDataToPermanentStore]; // maybe do in did instead?
// 注意不要在这里进行比耗时的操作,界面更流畅。
}
- (void)viewDidAppear:(BOOL)animated; //可以在显示之后做一些操作,比如动画之类的。
- (void)viewDidDisappear:(BOOL)animated;
都需要调用 super版本方法。在你的操作之前之后都行,看自己的需求。
- (void)view{Will,Did}LayoutSubviews;
- (id)initWithImage:(UIImage *)image;
// 他是个UIView,
@property (nonatomic, strong) UIImage *image; // will not adjust frame size
Top Left ScaleToFit 等属性。设置image的在UIImageView的边界缩放等。
UIWebView UIWebView
一个内置在UIView的完整的浏览器。
基于Webkit,一个HTML的开源的渲染框架。
支持javascript
重要的属性:
@property (nonatomic) BOOL scalesPagesToFit;
设置是否缩放到合适尺寸。YES就缩放到合适尺寸,如果NO,则保持原网页大小不变。
@property (nonatomic, readonly, strong) UIScrollView *scrollView;
控制滚动。
加载HTML的三个方法:
- (void)loadRequest:(NSURLRequest *)request;
- (void)loadHTMLString:(NSString *)string baseURL:(NSURL *)baseURL;
- (void)loadData:(NSData *)data
MIMEType:(NSString *)MIMEtype
textEncodingName:(NSString *)encodingName
baseURL:(NSURL *)baseURL;
NSURLRequest
NSURLRequest
+ (NSURLRequest *)requestWithURL:(NSURL *)url;
+ (NSURLRequest *)requestWithURL:(NSURL *)url
cachePolicy:(NSURLRequestCachePolicy)policy
timeoutInterval:(NSTimeInterval)timeoutInterval;
ScrollView 作用:
- 用户可以拖拽到想展示的内容区域
- 让用户可以放大缩小内容的区域
UIImage *image = [UIImage imageNamed:@"bigimage"];
UIImageView *iv = [[UIImageView alloc] initWithImage:image];
iv.frame = CGRectMake(0, 0, image.size.width, image.size.height);
CGRect fullScreenRect=[[UIScreen mainScreen] applicationFrame];
UIScrollView *scrollView=[[UIScrollView alloc] initWithFrame:fullScreenRect];
[scrollView addSubview:iv];
scrollView.contentSize=CGSizeMake(2592 ,1952);
[self.view addSubview:scrollView];
Reference
- https://medium.com/rocknnull/ios-working-with-uiscrollview-uitextview-and-auto-layout-afa39fe2cac8
- https://medium.com/@piyush.dez/uiviewcontroller-lifecycle-c06799ac8b69
推荐阅读
- 2020-04-07vue中Axios的封装和API接口的管理
- iOS中的Block
- 记录iOS生成分享图片的一些问题,根据UIView生成固定尺寸的分享图片
- 2019-08-29|2019-08-29 iOS13适配那点事
- Hacking|Hacking with iOS: SwiftUI Edition - SnowSeeker 项目(一)
- iOS面试题--基础
- 接口|axios接口报错-参数类型错误解决
- iOS|iOS 笔记之_时间戳 + DES 加密
- iOS,打Framework静态库
- 常用git命令总结