iOS-UITableViewCell自適應(yīng)高度最優(yōu)雅的方法

在iOS開發(fā)當(dāng)中,如果涉及到UITableViewCell的一些復(fù)雜UI的繪制時(shí)難免會(huì)碰到這么一個(gè)難題:UITableViewCell的高度如何設(shè)置!

的確廊鸥,我們就拿一個(gè)簡(jiǎn)單的例子來說:一個(gè)Cell上共耍,有頭像,有昵稱晰房,有評(píng)論內(nèi)容,還有圖片等控件,其中評(píng)論內(nèi)容的字?jǐn)?shù)并不能確定冈涧,那就決定了其每一個(gè)Cell的高度不定。比如下面我所做的一個(gè)項(xiàng)目中的評(píng)論:

圖1:簡(jiǎn)單的評(píng)論

從圖1中可以看到正蛙,Cell的頭像督弓,昵稱,發(fā)表日期的frame是固定的乒验,但是評(píng)論的內(nèi)容是有多有少的愚隧,因此frame并不確定,為此Cell的高度也不確定锻全。

在最開始開發(fā)的時(shí)候狂塘,大家都知道UITableView有一個(gè)獲取cell高度的代理方法,可以從這個(gè)方法當(dāng)中設(shè)置Cell的高度鳄厌,即:

圖2:獲取高度方法

那么自然而然的就可以想到這種辦法來設(shè)置高度:定義一個(gè)全局的Cell荞胡,在圖2的方法上給cell賦值,讓評(píng)論的Label執(zhí)行sizeToFit部翘,重新計(jì)算Cell的高度硝训,然后返回Cell的高度。

說實(shí)話,這種思路能實(shí)現(xiàn)效果窖梁,但是說實(shí)話:太Low了赘风,代碼太臟了。我能想到的就有下面幾個(gè)缺點(diǎn):

1.給Cell賦了兩次值纵刘,效率不高

2.如果Cell的布局更改邀窃,那么要改的地方可就多了

3.邏輯有點(diǎn)反反復(fù)復(fù)

當(dāng)然,別人還寫過別的Cell高度計(jì)算方法假哎,但是異曲同工瞬捕,都十分的Low,不優(yōu)雅舵抹。代碼我就不po出來了肪虎,太臟,懶得po出來惧蛹。

那么有沒有一種簡(jiǎn)單有效并且十分優(yōu)雅的方式來實(shí)現(xiàn)Cell的自適應(yīng)高度呢扇救?當(dāng)然有。我上篇文章過:蘋果推薦的方案就是最優(yōu)雅的香嗓。

下面小編我就說說蘋果推薦的方案:

步驟1:設(shè)置tableView.rowHeight =?UITableViewAutomaticDimension迅腔。

解釋:如此設(shè)置之后,就不必要寫圖2的獲取高度方法了靠娱。(注:默認(rèn)值就是UITableViewAutomaticDimension沧烈,但是為了整個(gè)流程還是寫出來了,)像云。

步驟2:設(shè)置tableView.estimatedRowHeight = 100锌雀。

解釋:設(shè)置一個(gè)預(yù)估的行高,為了代碼的易讀性苫费,還是盡量要設(shè)置一個(gè)跟cell的高差不多的值汤锨。

做了上面的步驟之后,剩下的就是繪制Cell了百框,這里就涉及到一個(gè)思想:根據(jù)內(nèi)容自動(dòng)撐開闲礼。這個(gè)解釋起來就有點(diǎn)麻煩,先看代碼(控件的創(chuàng)建就不po出來了铐维,誰都會(huì))柬泽。

步驟3:

圖3:設(shè)置頭像的約束

步驟4與步驟5:

圖4:設(shè)置評(píng)論的約束

根據(jù)圖3與圖4的代碼,作如下解釋:UITableViewCell上有一個(gè)contentView嫁蛇,contentView上面放置了所有的控件锨并。而這里的最頂部的控件avatarButton(頭像按鈕)頭部頂著contentView的頭部,contentLabel(評(píng)論label)頭部頂著avatarButton(頭像按鈕)的底部睬棚,同時(shí)contentLabel(評(píng)論label)底部有頂著contentView的底部第煮,為此就實(shí)現(xiàn)了avatarButton與contentLabel共同將contentView給撐開了解幼,也就把cell給撐開了。

那么會(huì)有人問:那contentLabel的高度怎么出來包警?其實(shí)從圖4可以看到我根本是沒有設(shè)置contentLabel的height撵摆,原因就是contentLabel的text就決定了contentLabel的高度,內(nèi)容的多少會(huì)自動(dòng)將contentLabel的高度撐開害晦。

這就是我上面說到的根據(jù)內(nèi)容自動(dòng)撐開的思想特铝。

以下就是一個(gè)簡(jiǎn)單的demo:代碼

效果:

效果圖
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末壹瘟,一起剝皮案震驚了整個(gè)濱河市鲫剿,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌稻轨,老刑警劉巖灵莲,帶你破解...
    沈念sama閱讀 217,826評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異澄者,居然都是意外死亡笆呆,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門粱挡,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人俄精,你說我怎么就攤上這事询筏。” “怎么了竖慧?”我有些...
    開封第一講書人閱讀 164,234評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵嫌套,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我圾旨,道長(zhǎng)踱讨,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,562評(píng)論 1 293
  • 正文 為了忘掉前任砍的,我火速辦了婚禮痹筛,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘廓鞠。我一直安慰自己帚稠,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,611評(píng)論 6 392
  • 文/花漫 我一把揭開白布床佳。 她就那樣靜靜地躺著滋早,像睡著了一般。 火紅的嫁衣襯著肌膚如雪砌们。 梳的紋絲不亂的頭發(fā)上杆麸,一...
    開封第一講書人閱讀 51,482評(píng)論 1 302
  • 那天搁进,我揣著相機(jī)與錄音,去河邊找鬼昔头。 笑死拷获,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的减细。 我是一名探鬼主播匆瓜,決...
    沈念sama閱讀 40,271評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼未蝌!你這毒婦竟也來了驮吱?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,166評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤萧吠,失蹤者是張志新(化名)和其女友劉穎左冬,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體纸型,經(jīng)...
    沈念sama閱讀 45,608評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡拇砰,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,814評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了狰腌。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片除破。...
    茶點(diǎn)故事閱讀 39,926評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖琼腔,靈堂內(nèi)的尸體忽然破棺而出瑰枫,到底是詐尸還是另有隱情,我是刑警寧澤丹莲,帶...
    沈念sama閱讀 35,644評(píng)論 5 346
  • 正文 年R本政府宣布光坝,位于F島的核電站,受9級(jí)特大地震影響甥材,放射性物質(zhì)發(fā)生泄漏盯另。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,249評(píng)論 3 329
  • 文/蒙蒙 一洲赵、第九天 我趴在偏房一處隱蔽的房頂上張望鸳惯。 院中可真熱鬧,春花似錦板鬓、人聲如沸悲敷。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽后德。三九已至,卻和暖如春抄腔,著一層夾襖步出監(jiān)牢的瞬間瓢湃,已是汗流浹背理张。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留绵患,地道東北人雾叭。 一個(gè)月前我還...
    沈念sama閱讀 48,063評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像落蝙,于是被迫代替她去往敵國(guó)和親织狐。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,871評(píng)論 2 354

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