關(guān)于iOS11中estimatedRowHeight

相信大家都已經(jīng)升級(jí)了iOS11居凶,而且也做了相應(yīng)的適配劫樟,其中對(duì)于tableView這個(gè)控件進(jìn)行適配的時(shí)候里烦,有很多情況下际插,很多資料都有說(shuō)需要把estimatedRowHeight屬性設(shè)置為0哼审,那么它到底是什么谐腰,為什么要這么來(lái)做,我們來(lái)探究下涩盾。

什么是estimatedRowHeight十气?

官方文檔描述

簡(jiǎn)而言之estimatedRowHeight是一個(gè)預(yù)估高度,iOS11之前是為0春霍,在iOS11下砸西,這個(gè)值默認(rèn)為44。

我們知道tableView是繼承于ScrollView的址儒,一個(gè)scrollView能滑動(dòng)芹枷,需要設(shè)置contentSize,那么tableView的contentSize怎么來(lái)呢莲趣?iOS11之前鸳慈,會(huì)調(diào)用tableView每一個(gè)cell的heightForRowAtIndexPath來(lái)算出整個(gè)高度,從而相加得出contentSize來(lái)喧伞,這一個(gè)步驟挺耗性能走芋!

所以iOS11,默認(rèn)打開(kāi)了estimatedRowHeight估算高度功能潘鲫,當(dāng)tableView創(chuàng)建完成后翁逞,contentSize為estimatedRowHeight(默認(rèn)值為44)*cell的數(shù)量,不需要遍歷每一個(gè)cell的heightForRowAtIndexPath來(lái)計(jì)算了溉仑。但是這樣子真實(shí)的contentSize又怎么得出來(lái)呢挖函?

不要急,我們看官方文檔的描述浊竟,里面的一句話


image.png

也就是說(shuō)在滑動(dòng)的時(shí)候怨喘,來(lái)計(jì)算這個(gè)值。具體是怎么計(jì)算的逐沙,我們可以舉2個(gè)例子:

例子一

我們創(chuàng)建一個(gè)TableView哲思,在iPhone7(iOS11)下,origin = (x = 0, y = 20)吩案,size = (width = 375, height = 657),此時(shí)方法返回的cell高度為50

-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{
      return 100;
}

 -(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath{
      return 50;
}

-(void)scrollViewDidScroll:(UIScrollView *)scrollView {
      NSLog(@"table ContentSize %@",  NSStringFromCGSize(scrollView.contentSize));
}
TableView

結(jié)果我們可以看到下圖帝簇,初始高度為100 * 44=4400

table ContentSize {375, 4400}

當(dāng)我往下拉(往下不是往上)徘郭,不會(huì)出現(xiàn)新的cell靠益,僅僅是為了觸發(fā)scrollViewDidScroll這個(gè)方法來(lái)打印出下面語(yǔ)句來(lái)

table ContentSize {375, 4490}

這個(gè)值怎么出來(lái)的呢?按照計(jì)算的話残揉,也應(yīng)該是4400+(50-44)*13=4478 (這里50-44是每一行的實(shí)際高度和預(yù)估的高度的差值胧后;13是界面顯示出0~12,總共13行)抱环。

后面經(jīng)過(guò)調(diào)試你會(huì)發(fā)現(xiàn)壳快,實(shí)際上會(huì)調(diào)用15次heightForRow的方法,這15次镇草,是預(yù)估高度為44眶痰,在657高度的屏幕上,會(huì)顯示出657/44=15個(gè)cell出來(lái)梯啤,所以它的實(shí)際計(jì)算會(huì)根據(jù)這個(gè)值來(lái)進(jìn)行竖伯,那么此時(shí)我們就能得出正確的結(jié)論來(lái)了4400+15*(50-44)=4490。

后面當(dāng)你每次顯示出新的cell出來(lái)的時(shí)候因宇,再進(jìn)行調(diào)整七婴,增加50-44=6的高度。

例子二

和例子一的區(qū)別在于察滑,cell高度返回為30打厘,也就是小于預(yù)估高度44,其余不變

 -(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath{
        return 30;
}
TableView2

結(jié)果我們可以看到下圖贺辰,初始高度為100 * 44=4400

table ContentSize {375, 4400}

當(dāng)我往下拉(往下不是往上)户盯,不會(huì)出現(xiàn)新的cell,僅僅是為了觸發(fā)scrollViewDidScroll這個(gè)方法來(lái)打印出下面語(yǔ)句來(lái)

table ContentSize {375, 4092}

按照例子一的解釋?zhuān)覀冇?jì)算下:4400 -(44-30)15= 4190 ;曜Α先舷!它又是怎么來(lái)的呢?經(jīng)過(guò)調(diào)試滓侍,我們發(fā)現(xiàn)它調(diào)用了heightForRow這個(gè)方法22次蒋川,也就是目前顯示在屏幕上的可見(jiàn)cell數(shù)量,按照這個(gè)撩笆,確實(shí)符合:4400 -(44-30)22= 4092捺球。同樣的,當(dāng)你往上滑動(dòng)夕冲,出現(xiàn)新的cell的時(shí)候氮兵,contentSize的高度會(huì)減去(44-30)

總結(jié)

那么我們可以得出結(jié)論,當(dāng)你的實(shí)際高度大于預(yù)估高度的時(shí)候歹鱼,會(huì)按照預(yù)估高度下的cell的數(shù)量來(lái)計(jì)算contentSize泣栈,當(dāng)實(shí)際高度小于預(yù)估高度的時(shí)候,會(huì)按照實(shí)際高度下的cell的數(shù)量來(lái)計(jì)算contentSize。

如果我們要回到iOS11之前的效果南片,我們可以讓estimatedRowHeight=0掺涛,關(guān)閉這個(gè)預(yù)估高度的效果。

推薦一個(gè)iOS進(jìn)階公開(kāi)課:https://ke.qq.com/course/171725

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末疼进,一起剝皮案震驚了整個(gè)濱河市薪缆,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌伞广,老刑警劉巖拣帽,帶你破解...
    沈念sama閱讀 216,402評(píng)論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異嚼锄,居然都是意外死亡减拭,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)灾票,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)峡谊,“玉大人,你說(shuō)我怎么就攤上這事刊苍〖让牵” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,483評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵正什,是天一觀的道長(zhǎng)啥纸。 經(jīng)常有香客問(wèn)我,道長(zhǎng)婴氮,這世上最難降的妖魔是什么斯棒? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,165評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮主经,結(jié)果婚禮上荣暮,老公的妹妹穿的比我還像新娘。我一直安慰自己罩驻,他們只是感情好穗酥,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,176評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著惠遏,像睡著了一般砾跃。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上节吮,一...
    開(kāi)封第一講書(shū)人閱讀 51,146評(píng)論 1 297
  • 那天抽高,我揣著相機(jī)與錄音,去河邊找鬼透绩。 笑死翘骂,一個(gè)胖子當(dāng)著我的面吹牛壁熄,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播雏胃,決...
    沈念sama閱讀 40,032評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼请毛,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼志鞍!你這毒婦竟也來(lái)了瞭亮?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 38,896評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤固棚,失蹤者是張志新(化名)和其女友劉穎统翩,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體此洲,經(jīng)...
    沈念sama閱讀 45,311評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡厂汗,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,536評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了呜师。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片娶桦。...
    茶點(diǎn)故事閱讀 39,696評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖汁汗,靈堂內(nèi)的尸體忽然破棺而出衷畦,到底是詐尸還是另有隱情,我是刑警寧澤知牌,帶...
    沈念sama閱讀 35,413評(píng)論 5 343
  • 正文 年R本政府宣布祈争,位于F島的核電站,受9級(jí)特大地震影響角寸,放射性物質(zhì)發(fā)生泄漏菩混。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,008評(píng)論 3 325
  • 文/蒙蒙 一扁藕、第九天 我趴在偏房一處隱蔽的房頂上張望沮峡。 院中可真熱鬧,春花似錦亿柑、人聲如沸邢疙。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)秘症。三九已至,卻和暖如春式矫,著一層夾襖步出監(jiān)牢的瞬間乡摹,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,815評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工采转, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留聪廉,地道東北人瞬痘。 一個(gè)月前我還...
    沈念sama閱讀 47,698評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像板熊,于是被迫代替她去往敵國(guó)和親框全。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,592評(píng)論 2 353

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

  • 我們?cè)谏弦黄锻ㄟ^(guò)代碼自定義不等高cell》中學(xué)習(xí)了tableView的相關(guān)知識(shí)干签,本文將在上文的基礎(chǔ)上津辩,利用sto...
    啊世ka閱讀 1,506評(píng)論 2 7
  • 導(dǎo)航欄變化 高度變化 在iOS11中導(dǎo)航欄多了一個(gè)LargeTitleView,專(zhuān)門(mén)專(zhuān)門(mén)顯示大字標(biāo)題容劳。該Large...
    辰牧殤閱讀 1,052評(píng)論 4 6
  • 前言 蘋(píng)果WWDC開(kāi)發(fā)者大會(huì)上喘沿,終于發(fā)布了大家期待已久的iOS 11,有些新特性功能確實(shí)出人意料竭贩。不過(guò)大的方面蘋(píng)果...
    Mr_Say_Yes閱讀 3,318評(píng)論 6 15
  • UITableViewCell 高度計(jì)算 UITableView 詢(xún)問(wèn) cell 高度有兩種方式:1.rowHei...
    WeiHing閱讀 4,439評(píng)論 6 16
  • 市面上分布式關(guān)系型數(shù)據(jù)庫(kù)目前越來(lái)越多蚜印,大家的主要目標(biāo)就是解決關(guān)系型數(shù)據(jù)庫(kù)擴(kuò)展性問(wèn)題,但是流派主要分3波留量,分庫(kù)分表加...
    bucketli閱讀 9,710評(píng)論 2 2