標籤:ios nib xib initwithcoder awakefromnib
接著 iOS 使用nib檔案(一)來。
在TestNibView.m中有個方法
-(id)initWithCoder:(NSCoder *)aDecoder;
這個方法來自NSCoding協議。NSCoding協議如下,就兩個方法。
@protocol NSCoding- (void)encodeWithCoder:(NSCoder *)aCoder;- (id)initWithCoder:(NSCoder *)aDecoder; // NS_DESIGNATED_INITIALIZER@end
nib檔案能夠儲存和恢複對象就需要用到這兩個方法。我們在需要歸檔自己自訂的對象時,也會實現這兩個方法。 對於UIView(包括子類)和UIViewController(包括子類)系統都已經實現了這兩個方法。使用xib檔案執行個體化對象時,首先
- (NSArray *)loadNibNamed:(NSString *)name owner:(id)owner options:(NSDictionary *)options;
會被調用,接著,系統就會調用initWithCoder來執行個體化實現了NSCoding協議的對象,而沒有實現NSCoding協議的對象,會調用其init方法。按照文檔描述,initWithCoder只是loadNibNamed方法中的一部分。
在iOS 使用nib檔案(一)中說道TestNibView中的一個方法
+(instancetype)testNibView { return [[[NSBundle mainBundle]loadNibNamed:@"TestNibView" owner:self options:nil] firstObject]; } 這種使用了單獨的xib檔案的view只能通過代碼去使用,而沒有辦法在其他的xib中使用。假設在A.xib中,我們拖拽了一個UIView叫做View,將其class設定為TestNibView,這個時候,和TestNibView類關聯的xib就不是TestNibView.xib,而是View,我們可以在View上加一個按鈕,這個按鈕可以作為outlet和TestNibView的button關聯起來。
需要注意的是initWithCoder方法只是一個init方法,它只是確保init,至於outlet這些關聯在這個方法並沒有完成關係,這一步,列印self.button是nil。loadNibNamed還會在initWithCoder之後調用awakeFromNib。而到了awakeFromNib方法中,這些outlets、delegate才確保已全部關聯,這個方法中[super awakeFromNib]後列印self.button不為空白。一般來說,我們並不需要在awakeFromNib中做些什麼,除了那些沒有辦法在xib中設定的東西,重載記得調用[super awakeFromNib]。
著作權聲明:歡迎評論和轉載,但請保留出處!
iOS 使用nib檔案(二)