iOS:根據(jù)內(nèi)容動(dòng)態(tài)計(jì)算高度的UITableViewCell

當(dāng)需要做一個(gè)動(dòng)態(tài)分享的界面例如微博主頁(yè)、朋友圈等亮蛔。這時(shí)候就需要根據(jù)內(nèi)容計(jì)算UITableViewCell的高度了漱竖。cell的高度是固定值可以在自定義cell的類里返回cell的高度君珠,但是需要根據(jù)內(nèi)容動(dòng)態(tài)計(jì)算cell的高度時(shí)則需要?jiǎng)?chuàng)建一個(gè)ViewModel茅特,在這個(gè)ViewModel取到數(shù)據(jù)模型時(shí)計(jì)算子視圖的frame以及cell的高度。

先看demo效果


1.分析原型模塊

要做一個(gè)復(fù)雜的界面時(shí)爵川,通常把一個(gè)界面拆分為幾個(gè)小的模塊從而一一實(shí)現(xiàn)
下面把一個(gè)cell里的子視圖拆分為幾個(gè)模塊敷鸦。


上圖的微博的cell可以拆分為三大塊

  • 微博主體
  • 微博配圖
  • 工具條

上圖有轉(zhuǎn)發(fā)內(nèi)容的微博又可以分為幾個(gè)模塊。
分析好原型的模塊之后就可以一一實(shí)現(xiàn)

2.創(chuàng)建數(shù)據(jù)模型

這里我是用plist文件來(lái)模擬網(wǎng)絡(luò)請(qǐng)求獲取的數(shù)據(jù)寝贡。


.m文件
.h文件

3.創(chuàng)建ViewModel

這一步是最重要的扒披。

  • 當(dāng)ViewModel獲取到數(shù)據(jù)模型時(shí)就可以計(jì)算cell子視圖的frame以及cell的高度
    這一步需要在數(shù)據(jù)模型的setter方法里寫
.h
.m
  • 定義所有子視圖的Frame
@class Moments;
@interface MomentViewModel : NSObject

/**
 *  數(shù)據(jù)模型
 */
@property (nonatomic ,strong) Moments *moment;

/**
 *  主體Frame
 */
@property (nonatomic ,assign) CGRect momentsBodyFrame;

//昵稱Frame
@property (nonatomic ,assign) CGRect bodyNameFrame;
//頭像Frame
@property (nonatomic ,assign) CGRect bodyIconFrame;
//時(shí)間Frame
@property (nonatomic ,assign) CGRect bodyTimeFrame;
//正文Frame
@property (nonatomic ,assign) CGRect bodyTextFrame;
//圖片F(xiàn)rame
@property (nonatomic ,assign) CGRect bodyPhotoFrame;

/**
 *  工具條Frame
 */
@property (nonatomic, assign) CGRect momentsToolBarFrame;

//點(diǎn)贊Frame
@property (nonatomic ,assign) CGRect toolLikeFrame;
//評(píng)論Frame
@property (nonatomic ,assign) CGRect toolCommentFrame;

/**
 *  cell高度
 */
@property (nonatomic ,assign) CGFloat cellHeight;

@end
  • 計(jì)算子視圖的frame(詳細(xì)在代碼里)

4.Model轉(zhuǎn)ViewModel

在ViewController里把Model轉(zhuǎn)為ViewModel

- (NSMutableArray *)moments{
    if (!_moments) {
        _moments = [NSMutableArray array];
        _moments = [Moments moments];
    }
    return _moments;
}

- (NSMutableArray *)momentFrames{
    if (!_momentFrames) {
        _momentFrames = [NSMutableArray array];
        //數(shù)據(jù)模型 => ViewModel(包含cell子控件的Frame)
        for (Moments *moment in self.moments) {
            MomentViewModel *momentFrame = [[MomentViewModel alloc] init];
            momentFrame.moment = moment;
            [self.momentFrames addObject:momentFrame];
        }
    }
    return _momentFrames;
}

5.給自定義UITableViewCell賦值ViewModel

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{
    MomentsTableViewCell *cell = [MomentsTableViewCell momentsTableViewCellWithTableView:tableView];
    cell.momentFrames = self.momentFrames[indexPath.section];
    return cell;
}

6.優(yōu)化

當(dāng)數(shù)據(jù)很多列表過長(zhǎng)的時(shí)候優(yōu)化就勢(shì)在必行了,可以往以下幾個(gè)方面考慮

  • 當(dāng)用戶滑動(dòng)時(shí)不加載圖片(新浪微博的方法)
  • 異步加載圖片
  • 盡量不用系統(tǒng)提供的方法加載圓形頭像圃泡,而采用加載圓形圖片
  • 使用reloadSection進(jìn)行局部更新

最后源碼:
github地址

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末碟案,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子洞焙,更是在濱河造成了極大的恐慌蟆淀,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,252評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件澡匪,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡褒链,警方通過查閱死者的電腦和手機(jī)唁情,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)甫匹,“玉大人甸鸟,你說我怎么就攤上這事”福” “怎么了抢韭?”我有些...
    開封第一講書人閱讀 168,814評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)恍箭。 經(jīng)常有香客問我刻恭,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,869評(píng)論 1 299
  • 正文 為了忘掉前任鳍贾,我火速辦了婚禮鞍匾,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘骑科。我一直安慰自己橡淑,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,888評(píng)論 6 398
  • 文/花漫 我一把揭開白布咆爽。 她就那樣靜靜地躺著梁棠,像睡著了一般。 火紅的嫁衣襯著肌膚如雪斗埂。 梳的紋絲不亂的頭發(fā)上掰茶,一...
    開封第一講書人閱讀 52,475評(píng)論 1 312
  • 那天,我揣著相機(jī)與錄音蜜笤,去河邊找鬼濒蒋。 笑死,一個(gè)胖子當(dāng)著我的面吹牛把兔,可吹牛的內(nèi)容都是我干的沪伙。 我是一名探鬼主播,決...
    沈念sama閱讀 41,010評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼县好,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼围橡!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起缕贡,我...
    開封第一講書人閱讀 39,924評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤翁授,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后晾咪,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體收擦,經(jīng)...
    沈念sama閱讀 46,469評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,552評(píng)論 3 342
  • 正文 我和宋清朗相戀三年谍倦,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了塞赂。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,680評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡昼蛀,死狀恐怖宴猾,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情叼旋,我是刑警寧澤仇哆,帶...
    沈念sama閱讀 36,362評(píng)論 5 351
  • 正文 年R本政府宣布,位于F島的核電站夫植,受9級(jí)特大地震影響讹剔,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,037評(píng)論 3 335
  • 文/蒙蒙 一辟拷、第九天 我趴在偏房一處隱蔽的房頂上張望撞羽。 院中可真熱鬧,春花似錦衫冻、人聲如沸诀紊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)邻奠。三九已至,卻和暖如春为居,著一層夾襖步出監(jiān)牢的瞬間碌宴,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工蒙畴, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留贰镣,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,099評(píng)論 3 378
  • 正文 我出身青樓膳凝,卻偏偏與公主長(zhǎng)得像碑隆,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子蹬音,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,691評(píng)論 2 361

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