【知識總結(jié)】xib 自定義視圖總結(jié)

xib文件的使用分為兩種:
1伞梯,使用代碼載入
2,在其他xib文件中通過綁定class使用自定義的xib文件

而這兩種方法的實(shí)現(xiàn),對建立xib文件時的設(shè)置又各不相同爪膊,在子控件進(jìn)行了連線的情況下,因此 同一個xib文件不能同時使用兩種方法去調(diào)用這個xib文件

配置方式
1砸王,使用代碼載入


2E528362-A4F2-4AB9-8B8D-91B6AE871418.png

如上圖所示推盛,將 custom view 綁定class,連接內(nèi)部的子控件到接口提供使用

使用 自定義的xib時谦铃,如果沒有設(shè)置尺寸耘成,會更具在 xib 文件中的大小顯示

2,在其他xib文件中通過綁定class使用自定義的xib文件

BA088021-6F59-4346-B664-F627E9FB680E.png

如上圖所示驹闰,將 file’s owner 的 custom class 改為 CustomView瘪菌,在對子控件進(jìn)行連線

要在 xib 中使用自定義的 xib 控件,上面的配置只是基礎(chǔ)嘹朗,還需要實(shí)現(xiàn)下面的方法(介紹在參考文章中):

#import "CustomView.h"
@implementation CustomView
/**
 *  這個方法需要設(shè)置 file's owner 綁定 class 時才使用
 */
- (id)initWithCoder:(NSCoder *)aDecoder
{
    if (self = [super initWithCoder:aDecoder]) {
        UIView *containerView = [[[UINib nibWithNibName:@"CustomView" bundle:nil] instantiateWithOwner:self options:nil] objectAtIndex:0];
        CGRect newFrame = CGRectMake(0, 0, self.frame.size.width, self.frame.size.height);
        containerView.frame = newFrame;
        [self addSubview:containerView];
    }
    return self;
}
/* 或?qū)崿F(xiàn)這個方法 */
//- (id) awakeAfterUsingCoder:(NSCoder*)aDecoder {
//    BOOL isJustAPlaceholder = ([[self subviews] count] == 0);
//    if (isJustAPlaceholder) {
//        CustomView* theRealThing = [[self class] getClassObjectFromNib];
//
//        theRealThing.frame = self.frame;    // ... (pass through selected properties)
//
//        // Update 2013-07-23: make compatible with Auto Layout
//        self.translatesAutoresizingMaskIntoConstraints = NO;
//        theRealThing.translatesAutoresizingMaskIntoConstraints = NO;
//
//        // convince ARC that we're legit -- Update 2013-03-10: unnecessary since at least Xcode 4.5
//        CFRelease((__bridge const void*)self);
//        CFRetain((__bridge const void*)theRealThing);
//
//        return theRealThing;
//    }
//    return self;
//}

@end

可能出現(xiàn)的問題:

5ABA6A1B-229C-4807-B753-5808A966003C.png

這個問題的出現(xiàn)情景是:
使用代碼的方式使用 xib 文件
原因:
使用了第 2 種方式(在其他xib文件中通過綁定class使用自定義的xib文件)配置 xib 文件师妙,并且子控件進(jìn)行了連線;如果子控件沒有進(jìn)行連線骡显,是可以正常運(yùn)行的疆栏,不會報錯
解決自然是從新配置成第 1 中方式

參考文章:
http://www.tuicool.com/articles/ENv6Nf/
上面截圖直接使用文章提供的 demo
文章 demo 地址:https://github.com/wtlucky/nestedXibLoad

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末曾掂,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子壁顶,更是在濱河造成了極大的恐慌珠洗,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,378評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件若专,死亡現(xiàn)場離奇詭異许蓖,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)调衰,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,970評論 3 399
  • 文/潘曉璐 我一進(jìn)店門膊爪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人嚎莉,你說我怎么就攤上這事米酬。” “怎么了趋箩?”我有些...
    開封第一講書人閱讀 168,983評論 0 362
  • 文/不壞的土叔 我叫張陵赃额,是天一觀的道長。 經(jīng)常有香客問我叫确,道長跳芳,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,938評論 1 299
  • 正文 為了忘掉前任竹勉,我火速辦了婚禮飞盆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘次乓。我一直安慰自己吓歇,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,955評論 6 398
  • 文/花漫 我一把揭開白布檬输。 她就那樣靜靜地躺著照瘾,像睡著了一般。 火紅的嫁衣襯著肌膚如雪丧慈。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,549評論 1 312
  • 那天主卫,我揣著相機(jī)與錄音逃默,去河邊找鬼。 笑死簇搅,一個胖子當(dāng)著我的面吹牛完域,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播瘩将,決...
    沈念sama閱讀 41,063評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼吟税,長吁一口氣:“原來是場噩夢啊……” “哼凹耙!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起肠仪,我...
    開封第一講書人閱讀 39,991評論 0 277
  • 序言:老撾萬榮一對情侶失蹤肖抱,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后异旧,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體意述,經(jīng)...
    沈念sama閱讀 46,522評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,604評論 3 342
  • 正文 我和宋清朗相戀三年吮蛹,在試婚紗的時候發(fā)現(xiàn)自己被綠了荤崇。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,742評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡潮针,死狀恐怖术荤,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情每篷,我是刑警寧澤喜每,帶...
    沈念sama閱讀 36,413評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站雳攘,受9級特大地震影響带兜,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜吨灭,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,094評論 3 335
  • 文/蒙蒙 一刚照、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧喧兄,春花似錦无畔、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,572評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至拯辙,卻和暖如春郭变,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背涯保。 一陣腳步聲響...
    開封第一講書人閱讀 33,671評論 1 274
  • 我被黑心中介騙來泰國打工诉濒, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人夕春。 一個月前我還...
    沈念sama閱讀 49,159評論 3 378
  • 正文 我出身青樓未荒,卻偏偏與公主長得像,于是被迫代替她去往敵國和親及志。 傳聞我的和親對象是個殘疾皇子片排,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,747評論 2 361

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理寨腔,服務(wù)發(fā)現(xiàn),斷路器率寡,智...
    卡卡羅2017閱讀 134,714評論 18 139
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,312評論 25 707
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫迫卢、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,123評論 4 61
  • 請問那位大神知道,醬怎么做比默?雞蛋煎餅的醬
    帖帖強(qiáng)閱讀 201評論 0 0
  • 想到一本書的名字幻捏,叫做《沒有任何借口》,確實(shí)在生活中命咐,我們總是以各種各樣的理由篡九,為自己的懶惰和不想做,找各種各樣的...
    林妖妖的盛夏光年閱讀 162評論 0 6