iOS UITableview實(shí)現(xiàn)展開(kāi)折疊效果

使用UItableview實(shí)現(xiàn)展開(kāi)折疊效果,話(huà)不多說(shuō),先看一下運(yùn)行效果:

001.gif
講一下實(shí)現(xiàn)的大概思路:
  1. 自定義每個(gè)section的headerView,并且給headerView添加tap手勢(shì).
  2. 在tap觸發(fā)的方法中判斷當(dāng)前點(diǎn)擊的section狀態(tài),然后調(diào)用*- (void)reloadSections:(NSIndexSet )sections withRowAnimation:方法刷新section.
幾個(gè)關(guān)鍵的地方:

1.在點(diǎn)擊section的時(shí)候,需要判斷當(dāng)前點(diǎn)擊的section的狀態(tài)是展開(kāi)還是關(guān)閉.我用的方法是創(chuàng)建了一個(gè)NSMutableArray,在這個(gè)數(shù)組中添加和section的count相同的元素,這里我存放的就是0和1的字符串,0代表關(guān)閉,1代表展開(kāi),代碼如下:

 for (NSInteger i = 0; i < _provinceArray.count; i++) {
        [_isExpandArray addObject:@"0"];//0:沒(méi)展開(kāi) 1:展開(kāi)
    }

如果你有更好的方法,可以留言告訴我一下,謝謝~

2.在numberOfRowsInSection這個(gè)方法中,需要根據(jù)標(biāo)識(shí),來(lái)決定每個(gè)section中row的個(gè)數(shù),記住,千萬(wàn)不要寫(xiě)死了.

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{
    if ([_isExpandArray[section]isEqualToString:@"1"]) {
        NSString *keyProvince = _provinceArray[section];
        NSArray *cityArray = [_provinceDic objectForKey:keyProvince];
        return  cityArray.count;
    }else{
        return 0;
    }
}

3.最后一個(gè)比較關(guān)鍵的點(diǎn)就是tap手勢(shì)所觸發(fā)的方法,這個(gè)方法主要做兩件事:首先要判斷section的狀態(tài),更改小三角形的圖標(biāo);然后調(diào)用reloadSections刷新section:

- (void)tapAction:(UITapGestureRecognizer *)tap{
    if ([_isExpandArray[tap.view.tag] isEqualToString:@"0"]) {
        //關(guān)閉 => 展開(kāi)
        [_isExpandArray removeObjectAtIndex:tap.view.tag];
        [_isExpandArray insertObject:@"1" atIndex:tap.view.tag];
    }else{
        //展開(kāi) => 關(guān)閉
        [_isExpandArray removeObjectAtIndex:tap.view.tag];
        [_isExpandArray insertObject:@"0" atIndex:tap.view.tag];
        
    }
    NSIndexPath *indexPath = [NSIndexPath indexPathForItem:0 inSection:tap.view.tag];
    NSRange rang = NSMakeRange(indexPath.section, 1);
    NSIndexSet *set = [NSIndexSet indexSetWithIndexesInRange:rang];
    [_provinceTableView reloadSections:set withRowAnimation:UITableViewRowAnimationFade];
    
}

通過(guò)這幾步就能實(shí)現(xiàn)展開(kāi)收起的效果了.demo下載點(diǎn)擊這里

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末鸵贬,一起剝皮案震驚了整個(gè)濱河市宅此,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌烁涌,老刑警劉巖尿这,帶你破解...
    沈念sama閱讀 210,978評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件撞羽,死亡現(xiàn)場(chǎng)離奇詭異认罩,居然都是意外死亡稠歉,警方通過(guò)查閱死者的電腦和手機(jī)掰担,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)怒炸,“玉大人带饱,你說(shuō)我怎么就攤上這事≡母” “怎么了勺疼?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,623評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)捏鱼。 經(jīng)常有香客問(wèn)我执庐,道長(zhǎng),這世上最難降的妖魔是什么导梆? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,324評(píng)論 1 282
  • 正文 為了忘掉前任轨淌,我火速辦了婚禮,結(jié)果婚禮上看尼,老公的妹妹穿的比我還像新娘递鹉。我一直安慰自己,他們只是感情好狡忙,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布梳虽。 她就那樣靜靜地躺著,像睡著了一般灾茁。 火紅的嫁衣襯著肌膚如雪窜觉。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,741評(píng)論 1 289
  • 那天北专,我揣著相機(jī)與錄音禀挫,去河邊找鬼。 笑死拓颓,一個(gè)胖子當(dāng)著我的面吹牛语婴,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 38,892評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼砰左,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼匿醒!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起缠导,我...
    開(kāi)封第一講書(shū)人閱讀 37,655評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤廉羔,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后僻造,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體憋他,經(jīng)...
    沈念sama閱讀 44,104評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年髓削,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了竹挡。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,569評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡立膛,死狀恐怖揪罕,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情旧巾,我是刑警寧澤耸序,帶...
    沈念sama閱讀 34,254評(píng)論 4 328
  • 正文 年R本政府宣布,位于F島的核電站鲁猩,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏罢坝。R本人自食惡果不足惜廓握,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望嘁酿。 院中可真熱鬧隙券,春花似錦、人聲如沸闹司。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,725評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)游桩。三九已至牲迫,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間借卧,已是汗流浹背盹憎。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,950評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留铐刘,地道東北人陪每。 一個(gè)月前我還...
    沈念sama閱讀 46,260評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親檩禾。 傳聞我的和親對(duì)象是個(gè)殘疾皇子挂签,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評(píng)論 2 348

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

  • 1.badgeVaule氣泡提示 2.git終端命令方法> pwd查看全部 >cd>ls >之后桌面找到文件夾內(nèi)容...
    i得深刻方得S閱讀 4,640評(píng)論 1 9
  • *7月8日上午 N:Block :跟一個(gè)函數(shù)塊差不多,會(huì)對(duì)里面所有的內(nèi)容的引用計(jì)數(shù)+1盼产,想要解決就用__block...
    炙冰閱讀 2,477評(píng)論 1 14
  • 版權(quán)聲明:未經(jīng)本人允許,禁止轉(zhuǎn)載. 1. TableView初始化 1.UITableView有兩種風(fēng)格:UITa...
    蕭雪痕閱讀 2,908評(píng)論 2 10
  • 也許只有深夜才有最安靜的環(huán)境以此滋生最敏感的神經(jīng)饵婆,觸動(dòng)靈魂最深處的柔軟。 有時(shí)候我總會(huì)覺(jué)得這個(gè)世界上我其實(shí)是什么都...
    微醺IAZIJI閱讀 450評(píng)論 3 3
  • 端午過(guò)去不久辆飘,假期還沒(méi)享受完就急急忙忙來(lái)了工作啦辐,本來(lái)假期前想寫(xiě)這遍文章的,結(jié)果一直忙的沒(méi)空蜈项,對(duì)于微信朋友圈和微博上...
    Luke_單車(chē)閱讀 14,356評(píng)論 27 61