UIView生命周期详解

UIView生命周期详解

View代码实现

  • 一般情况
MyView *myView = [[MyView alloc] init];
[self.view addSubview:myView];
// 初始化过程
2019-04-12 14:44:47.558747+0800 UIViewLifeDemo[12529:360679] Step 1 -- -[MyView initWithFrame:]
2019-04-12 14:44:47.558957+0800 UIViewLifeDemo[12529:360679] Step 2 -- -[MyView init]
2019-04-12 14:44:47.559035+0800 UIViewLifeDemo[12529:360679] Step 3 -- -[MyView willMoveToSuperview:]
2019-04-12 14:44:47.559131+0800 UIViewLifeDemo[12529:360679] Step 4 -- -[MyView didMoveToSuperview]
2019-04-12 14:44:47.569525+0800 UIViewLifeDemo[12529:360679] Step 5 -- -[MyView willMoveToWindow:]
2019-04-12 14:44:47.569683+0800 UIViewLifeDemo[12529:360679] Step 6 -- -[MyView didMoveToWindow]
2019-04-12 14:44:47.591882+0800 UIViewLifeDemo[12529:360679] Step 7 -- -[MyView layoutSubviews]

// 销毁过程
2019-04-12 14:44:56.431678+0800 UIViewLifeDemo[12529:360679] Step 8 -- -[MyView willMoveToWindow:]
2019-04-12 14:44:56.431824+0800 UIViewLifeDemo[12529:360679] Step 9 -- -[MyView didMoveToWindow]
2019-04-12 14:44:56.432235+0800 UIViewLifeDemo[12529:360679] Step 10 -- -[MyView removeFromSuperview]
2019-04-12 14:44:56.432473+0800 UIViewLifeDemo[12529:360679] Step 11 -- -[MyView dealloc]
  • 重复地移除再添加到相同的SuperView,willMoveToSuperview和didMoveToSuperview不会重复调用。
MyView *myView = [[MyView alloc] init];
    
for (int n = 0; n < 4; n++) {
    [self.view addSubview:myView];
    [myView removeFromSuperview];
}
// 初始化过程
2019-04-12 15:13:27.774165+0800 UIViewLifeDemo[14955:381550] Step 1 -- -[MyView initWithFrame:]
2019-04-12 15:13:27.774380+0800 UIViewLifeDemo[14955:381550] Step 2 -- -[MyView init]
2019-04-12 15:13:27.774450+0800 UIViewLifeDemo[14955:381550] Step 3 -- -[MyView willMoveToSuperview:]
2019-04-12 15:13:27.774539+0800 UIViewLifeDemo[14955:381550] Step 4 -- -[MyView didMoveToSuperview]
2019-04-12 15:13:27.774684+0800 UIViewLifeDemo[14955:381550] Step 5 -- -[MyView removeFromSuperview]
2019-04-12 15:13:27.774773+0800 UIViewLifeDemo[14955:381550] Step 6 -- -[MyView removeFromSuperview]
2019-04-12 15:13:27.774863+0800 UIViewLifeDemo[14955:381550] Step 7 -- -[MyView removeFromSuperview]
2019-04-12 15:13:27.774951+0800 UIViewLifeDemo[14955:381550] Step 8 -- -[MyView removeFromSuperview]
2019-04-12 15:13:27.782601+0800 UIViewLifeDemo[14955:381550] Step 9 -- -[MyView willMoveToWindow:]
2019-04-12 15:13:27.782798+0800 UIViewLifeDemo[14955:381550] Step 10 -- -[MyView didMoveToWindow]
2019-04-12 15:13:27.797559+0800 UIViewLifeDemo[14955:381550] Step 11 -- -[MyView layoutSubviews]
  • 重复地移除再添加到不同的SuperView,willMoveToSuperview和didMoveToSuperview会重复调用。
MyView *myView = [[MyView alloc] init];
    
UIView *view0 = [[UIView alloc] init];
UIView *view1 = [[UIView alloc] init];
    
for (int n = 0; n < 4; n++) {
    if (n % 2 == 0) {
        [view0 addSubview:myView];
    }
    else {
        [view1 addSubview:myView];
    }
    
    [myView removeFromSuperview];
}
    
[self.view addSubview:myView];
// 初始化过程
2019-04-12 15:21:07.953595+0800 UIViewLifeDemo[15040:386253] Step 1 -- -[MyView initWithFrame:]
2019-04-12 15:21:07.953780+0800 UIViewLifeDemo[15040:386253] Step 2 -- -[MyView init]
2019-04-12 15:21:07.953927+0800 UIViewLifeDemo[15040:386253] Step 3 -- -[MyView willMoveToSuperview:]
2019-04-12 15:21:07.954039+0800 UIViewLifeDemo[15040:386253] Step 4 -- -[MyView didMoveToSuperview]
2019-04-12 15:21:07.954126+0800 UIViewLifeDemo[15040:386253] Step 5 -- -[MyView removeFromSuperview]
2019-04-12 15:21:07.954193+0800 UIViewLifeDemo[15040:386253] Step 6 -- -[MyView willMoveToSuperview:]
2019-04-12 15:21:07.954276+0800 UIViewLifeDemo[15040:386253] Step 7 -- -[MyView didMoveToSuperview]
2019-04-12 15:21:07.954390+0800 UIViewLifeDemo[15040:386253] Step 8 -- -[MyView removeFromSuperview]
2019-04-12 15:21:07.954629+0800 UIViewLifeDemo[15040:386253] Step 9 -- -[MyView willMoveToSuperview:]
2019-04-12 15:21:07.954850+0800 UIViewLifeDemo[15040:386253] Step 10 -- -[MyView didMoveToSuperview]
2019-04-12 15:21:07.955045+0800 UIViewLifeDemo[15040:386253] Step 11 -- -[MyView removeFromSuperview]
2019-04-12 15:21:07.955218+0800 UIViewLifeDemo[15040:386253] Step 12 -- -[MyView willMoveToSuperview:]
2019-04-12 15:21:07.955427+0800 UIViewLifeDemo[15040:386253] Step 13 -- -[MyView didMoveToSuperview]
2019-04-12 15:21:07.955629+0800 UIViewLifeDemo[15040:386253] Step 14 -- -[MyView removeFromSuperview]
2019-04-12 15:21:07.955832+0800 UIViewLifeDemo[15040:386253] Step 15 -- -[MyView willMoveToSuperview:]
2019-04-12 15:21:07.956073+0800 UIViewLifeDemo[15040:386253] Step 16 -- -[MyView didMoveToSuperview]
2019-04-12 15:21:07.980502+0800 UIViewLifeDemo[15040:386253] Step 17 -- -[MyView willMoveToWindow:]
2019-04-12 15:21:07.980657+0800 UIViewLifeDemo[15040:386253] Step 18 -- -[MyView didMoveToWindow]
2019-04-12 15:21:07.994333+0800 UIViewLifeDemo[15040:386253] Step 19 -- -[MyView layoutSubviews]

View xib实现

  • 一般情况
// 初始化过程
2019-04-12 15:24:56.344593+0800 UIViewLifeDemo[15131:389556] Step 1 -- -[MyView initWithCoder:]
2019-04-12 15:24:56.344728+0800 UIViewLifeDemo[15131:389556] Step 2 -- -[MyView willMoveToSuperview:]
2019-04-12 15:24:56.344828+0800 UIViewLifeDemo[15131:389556] Step 3 -- -[MyView didMoveToSuperview]
2019-04-12 15:24:56.351139+0800 UIViewLifeDemo[15131:389556] Step 4 -- -[MyView willMoveToWindow:]
2019-04-12 15:24:56.351460+0800 UIViewLifeDemo[15131:389556] Step 5 -- -[MyView didMoveToWindow]
2019-04-12 15:24:56.364634+0800 UIViewLifeDemo[15131:389556] Step 6 -- -[MyView layoutSubviews]

// 销毁过程
2019-04-12 15:25:19.571373+0800 UIViewLifeDemo[15131:389556] Step 7 -- -[MyView willMoveToWindow:]
2019-04-12 15:25:19.571539+0800 UIViewLifeDemo[15131:389556] Step 8 -- -[MyView didMoveToWindow]
2019-04-12 15:25:19.572150+0800 UIViewLifeDemo[15131:389556] Step 9 -- -[MyView removeFromSuperview]
2019-04-12 15:25:19.572476+0800 UIViewLifeDemo[15131:389556] Step 10 -- -[MyView dealloc]
  • 在xib中修改View的属性,initWithCoder方法中就会生效

xib中的MyView修改了背景颜色,从日志可以看到背景颜色从-[MyView initWithCoder:]开始已经修改为#007affff。

2019-04-12 15:54:48.920910+0800 UIViewLifeDemo[15547:409869] Step 1 -- -[MyView initWithCoder:] -- backgroundColor #007affff
2019-04-12 15:54:48.921155+0800 UIViewLifeDemo[15547:409869] Step 2 -- -[MyView willMoveToSuperview:] -- backgroundColor #007affff
2019-04-12 15:54:48.921288+0800 UIViewLifeDemo[15547:409869] Step 3 -- -[MyView didMoveToSuperview] -- backgroundColor #007affff
2019-04-12 15:54:48.929106+0800 UIViewLifeDemo[15547:409869] Step 4 -- -[MyView willMoveToWindow:] -- backgroundColor #007affff
2019-04-12 15:54:48.929429+0800 UIViewLifeDemo[15547:409869] Step 5 -- -[MyView didMoveToWindow] -- backgroundColor #007affff
2019-04-12 15:54:48.941557+0800 UIViewLifeDemo[15547:409869] Step 6 -- -[MyView layoutSubviews] -- backgroundColor #007affff
  • 在Category中为View添加属性,并在xib中修改该属性,didMoveToSuperview方法执行后才会生效

在Category中为MyView添加myText属性

// MyView+Extension.h

IB_DESIGNABLE

@interface MyView (Extension)

@property(nonatomic, strong) IBInspectable NSString *myText;

@end



// MyView+Extension.m

@implementation MyView (Extension)

- (void)setMyText:(NSString *)myText {
    objc_setAssociatedObject(self, (__bridge const void * _Nonnull)(self), myText, OBJC_ASSOCIATION_RETAIN_NONATOMIC);
}

- (NSString *)myText {
    NSString *myText = objc_getAssociatedObject(self, (__bridge const void * _Nonnull)(self));
    return myText;
}

@end

在xib中设置myText的值, -[MyView didMoveToSuperview]执行完后才会生效

MyText.png
2019-04-12 15:59:48.380369+0800 UIViewLifeDemo[15605:413050] Step 1 -- -[MyView initWithCoder:] -- myText (null)
2019-04-12 15:59:48.380536+0800 UIViewLifeDemo[15605:413050] Step 2 -- -[MyView willMoveToSuperview:] -- myText (null)
2019-04-12 15:59:48.380626+0800 UIViewLifeDemo[15605:413050] Step 3 -- -[MyView didMoveToSuperview] -- myText (null)
2019-04-12 15:59:52.558483+0800 UIViewLifeDemo[15605:413050] Step 4 -- -[MyView willMoveToWindow:] -- myText Hello world
2019-04-12 15:59:52.558827+0800 UIViewLifeDemo[15605:413050] Step 5 -- -[MyView didMoveToWindow] -- myText Hello world
2019-04-12 15:59:52.574201+0800 UIViewLifeDemo[15605:413050] Step 6 -- -[MyView layoutSubviews] -- myText Hello world
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容