table view 多級聯(lián)動,使用方式類似picker view

2018/4/9更新
增加自定義cell接口饥侵,對原先函數(shù)命名方式調(diào)整鸵赫,一些bug修改

使用方式和使用picker view相似:
1、創(chuàng)建TablePickerView:

- (instancetype)initWithFrame:(CGRect)frame delegate:(id<TablePickerViewDataSource,TablePickerViewDelegate>)delegate;

2躏升、實(shí)現(xiàn)數(shù)據(jù)源代理TablePickerViewDataSource:

@optional
- (NSInteger)numberOfComponentsInTablePickerView:(TablePickerView *)tablePickerView;

- (NSString *)tablePickerView:(TablePickerView *)tablePickerView titleForRow:(NSInteger)row forComponent:(NSInteger)component;
/*!
 @brief 自定義每個(gè)選項(xiàng)視圖辩棒,如果現(xiàn)實(shí)該代理方法,tablePickerView:titleForRow: forComponent:方法將無效
 */
- (UITableViewCell *)tablePickerView:(TablePickerView *)tablePickerView  viewForRow:(NSInteger)row forComponent:(NSInteger)component;

@required
- (NSInteger)tablePickerView:(TablePickerView *)tablePickerView numberOfRowsInComponent:(NSInteger)component;

3膨疏、實(shí)現(xiàn)視圖代理TablePickerViewDelegate

@optional
- (CGFloat) tablePickerView:(TablePickerView *)tablePickerView widthForComponent:(NSInteger)component;

- (CGFloat) tablePickerView:(TablePickerView *)tablePickerView rowHeightForComponent:(NSInteger)component;

- (void) tablePickerView:(TablePickerView *)tablePickerView didSelectRow:(NSInteger)row inComponent:(NSInteger)component;

通過以上三步就可以實(shí)現(xiàn)table view 的基礎(chǔ)多級聯(lián)動了一睁,主要視圖在TablePickerView目錄下,具體怎么使用可看源碼:git地址

4佃却、需要自定義cell的話者吁,需要調(diào)用以下方法注冊和獲取復(fù)用cell

/*!
 @biref 獲取復(fù)用cell
 @param identifier 復(fù)用唯一標(biāo)識
 @param component 列
 @return 返回tableViewCell
 */
- (UITableViewCell *)dequeueReusableCellWithIdentifier:(NSString *)identifier forComponet:(NSInteger)component;

/*!
 @brief 使用xib創(chuàng)建cell
 @param identifier 復(fù)用唯一標(biāo)識
 @param component 列
 */
- (void)registerNib:(UINib *)nib forCellReuseIdentifier:(NSString *)identifier forComponet:(NSInteger)component;

/*!
 @brief 使用純代碼創(chuàng)建cell
 @param identifier 復(fù)用唯一標(biāo)識
 @param component 列
 */
- (void)registerClass:(Class)cellClass forCellReuseIdentifier:(NSString *)identifier forComponet:(NSInteger)component;
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市饲帅,隨后出現(xiàn)的幾起案子复凳,更是在濱河造成了極大的恐慌瘤泪,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,743評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件育八,死亡現(xiàn)場離奇詭異对途,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)髓棋,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,296評論 3 385
  • 文/潘曉璐 我一進(jìn)店門实檀,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人仲锄,你說我怎么就攤上這事劲妙。” “怎么了儒喊?”我有些...
    開封第一講書人閱讀 157,285評論 0 348
  • 文/不壞的土叔 我叫張陵镣奋,是天一觀的道長搞乏。 經(jīng)常有香客問我轰胁,道長框沟,這世上最難降的妖魔是什么障般? 我笑而不...
    開封第一講書人閱讀 56,485評論 1 283
  • 正文 為了忘掉前任稚叹,我火速辦了婚禮剂桥,結(jié)果婚禮上赖捌,老公的妹妹穿的比我還像新娘惫霸。我一直安慰自己扛拨,他們只是感情好耘分,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,581評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著绑警,像睡著了一般求泰。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上计盒,一...
    開封第一講書人閱讀 49,821評論 1 290
  • 那天渴频,我揣著相機(jī)與錄音,去河邊找鬼北启。 笑死卜朗,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的咕村。 我是一名探鬼主播场钉,決...
    沈念sama閱讀 38,960評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼懈涛!你這毒婦竟也來了惹悄?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,719評論 0 266
  • 序言:老撾萬榮一對情侶失蹤肩钠,失蹤者是張志新(化名)和其女友劉穎泣港,沒想到半個(gè)月后暂殖,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,186評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡当纱,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,516評論 2 327
  • 正文 我和宋清朗相戀三年呛每,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片坡氯。...
    茶點(diǎn)故事閱讀 38,650評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡晨横,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出箫柳,到底是詐尸還是另有隱情手形,我是刑警寧澤,帶...
    沈念sama閱讀 34,329評論 4 330
  • 正文 年R本政府宣布悯恍,位于F島的核電站库糠,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏涮毫。R本人自食惡果不足惜瞬欧,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,936評論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望罢防。 院中可真熱鬧艘虎,春花似錦、人聲如沸咒吐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,757評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽恬叹。三九已至候生,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間妄呕,已是汗流浹背陶舞。 一陣腳步聲響...
    開封第一講書人閱讀 31,991評論 1 266
  • 我被黑心中介騙來泰國打工嗽测, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留绪励,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,370評論 2 360
  • 正文 我出身青樓唠粥,卻偏偏與公主長得像疏魏,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子晤愧,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,527評論 2 349

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