詳解ios11中estimatedRowHeight屬性
相信大家都已經(jīng)升級(jí)了iOS11,而且也做了相應(yīng)的適配,其中對(duì)于tableView這個(gè)控件進(jìn)行適配的時(shí)候,比如:集成MJRefresh的時(shí)候,當(dāng)然還有其他很多情況下,很多資料都有說(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)呢?
不要急,我們看官方文檔的描述,里面的一句話(huà)

也就是說(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)); }

結(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ì)算的話(huà),也應(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;
}

結(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ù)估高度的效果。
延展
為什么使用MJRefresh在iOS11下要讓estimatedRowHeight=0,因?yàn)镸JRefresh底部的上拉刷新是根據(jù)contentSize來(lái)計(jì)算的,當(dāng)數(shù)據(jù)更新的時(shí)候,得出來(lái)的contentSize只是預(yù)估的。
相關(guān)文章
iOS實(shí)現(xiàn)圖片壓縮的兩種方法及圖片壓縮上傳功能
ios 圖片壓縮有兩種方法,分別是,壓縮圖片質(zhì)量(Quality),壓縮圖片尺寸(Size),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下2017-01-01
淺談關(guān)于如何檢測(cè)iOS14本地網(wǎng)絡(luò)權(quán)限的一些思路
這篇文章主要介紹了淺談關(guān)于如何檢測(cè)iOS14本地網(wǎng)絡(luò)權(quán)限的一些思路,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
ios開(kāi)發(fā)加載webview顯示進(jìn)度條實(shí)例
本篇文章主要介紹了ios開(kāi)發(fā)加載webview顯示進(jìn)度條實(shí)例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05
iOS開(kāi)發(fā)之通過(guò)銀行卡號(hào)獲取所屬銀行名稱(chēng)
本文給大家分享一段代碼關(guān)于ios通過(guò)銀行卡號(hào)獲取所屬銀行名稱(chēng),代碼簡(jiǎn)單易懂,在項(xiàng)目開(kāi)發(fā)中經(jīng)常會(huì)遇到這樣的功能,需要的朋友一起學(xué)習(xí)吧2016-11-11
iOS應(yīng)用中使用AsyncSocket庫(kù)處理Socket通信的用法講解
這篇文章主要介紹了iOS應(yīng)用中使用AsyncSocket庫(kù)處理Socket通信的用法講解,AsyncSocket同時(shí)支持TCP和UDP,文中展示了其建立斷開(kāi)連接及發(fā)送接收消息的操作,very好用,需要的朋友可以參考下2016-05-05
詳解iOS 滾動(dòng)視圖的復(fù)用問(wèn)題解決方案
本篇文章主要介紹iOS 滾動(dòng)視圖的復(fù)用問(wèn)題解決方案,具有一定的參考價(jià)值,有興趣的可以了解一下。2016-12-12
iOS應(yīng)用中UISearchDisplayController搜索效果的用法
這篇文章主要介紹了iOS應(yīng)用中UISearchDisplayController搜索效果的用法,包括點(diǎn)擊搜索出現(xiàn)黑條問(wèn)題的解決方法,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2016-02-02

