精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

iOS自適應cell行高的那點破事兒

移動開發
其實早就準備寫這篇文章了,但是一直沒有系統去整理一下相關的demo,加上最近離職了,各種事情忙的有點郁悶,所以一直拖沓了下來?;丶倚菹⒘艘欢螘r間想起來寫了一半的demo,在還沒找工作的這段空擋時間抽空完善了一下再寫篇說明文檔備忘一下。

前言

其實早就準備寫這篇文章了,但是一直沒有系統去整理一下相關的demo,加上最近離職了,各種事情忙的有點郁悶,所以一直拖沓了下來?;丶倚菹⒘艘欢螘r間想起來寫了一半的demo,在還沒找工作的這段空擋時間抽空完善了一下再寫篇說明文檔備忘一下。

[[248408]]

需求背景

iOS的cell行高自適應是個非常常見的需求,也是一個非常簡單的需求,之前我遇到過很多小伙伴不知道怎么來實現,在這里就一步步的來分析一下,供大家參考。

問題分析

其他的實現場景就不說了,我們現在來分析一下具體的需求,如圖所示:

iOS自適應cell行高的那點破事兒

cell行高自適應.png

其實主要實現這幾點就可以解決所謂的自適應行高的問題,下面我們就來逐步實現這個需求。

計算UITableViewCell的高度

說到計算高度,大家都不陌生,最簡單常見的就是計算出每個子視圖的高度累積起來返回我們所需要的cell高度,然后在UITableViewDelegate中調用:

 

  1. - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath 
  2.    return 666; 

或者高度固定的情況下直接

  1. self.tableView.rowHeight = 666; 

但是這就要求我們需要提前拿到model中的數據來手動計算每個控件的高度,這樣既麻煩又不能通用,所以在autolayout出來之后我們只要給cell的contentView的上下左右都添加了約束,系統就可以自動的幫我們實現高度的自適應,就是一定要保證cell的高度可以被子視圖撐開就可以了,利用的是systemLayoutSizeFittingSize這個API;

iOS8之后就更簡單了,直接使用:

 

  1. self.tableView.estimatedRowHeight = 666; 
  2. self.tableView.rowHeight = UITableViewAutomaticDimension; 

就可以了,其中estimatedRowHeight是預估高度,這里要注意delegate中的返回高度方法就不用在寫了。

關于這方面的文章,UITableView+FDTemplateLayoutCel的作者寫的一篇文章十分詳細,建議先去了解一下(優化UITableViewCell高度計算的那些事)

但是這個方法實際上在有多個子視圖的cell上滑動是很卡頓的,特別是在iOS8尤其是iOS10上卡頓尤為明顯,這跟系統的算高機制有一定關系,具體可以看上面的文章,這里不再解釋了。

如果脫離開autolayout來說,平時計算高度的話,最開始都是根據cell內子控件內容的高度來手動累加起來,但是這個方法每次都要去手動處理其中的算高邏輯,而且橫豎屏切換的時候還要重新計算,在平時開發中就會浪費大量不必要的精力。所以后來我在項目中是通過調用layoutSubviews來獲取到子控件的實際frame,這樣就可以得到我們所需的cell高度值,如下代碼所示:

 

  1. cell.frame = CGRectSetWidth(cell.frame, contentViewWidth); 
  2.     cell.contentView.frame = CGRectSetWidth(cell.contentView.frame, CGRectGetWidth(tableView.frame)); 
  3.     [cell layoutIfNeeded]; 
  4.  
  5.     UIView *cellBottomView = nil; 
  6.     if (cell.FS_cellBottomView) { 
  7.         cellBottomView = cell.FS_cellBottomView; 
  8.     }else if (cell.FS_cellBottomViews && cell.FS_cellBottomViews.count > 0) { 
  9.         cellBottomView = cell.FS_cellBottomViews[0]; 
  10.         for (UIView *view in cell.FS_cellBottomViews) { 
  11.             if (CGRectGetMaxY(view.frame) > CGRectGetMaxY(cellBottomView.frame)) { 
  12.                 cellBottomView = view
  13.             } 
  14.         } 
  15.     }else { 
  16.         NSArray *contentViewSubViews = cell.contentView.subviews; 
  17.         if (contentViewSubViews.count == 0) { 
  18.             cellBottomView = cell.contentView; 
  19.         }else
  20.             cellBottomView = contentViewSubViews[0]; 
  21.             for (UIView *view in contentViewSubViews) { 
  22.                 if (CGRectGetMaxY(view.frame) > CGRectGetMaxY(cellBottomView.frame)) { 
  23.                     cellBottomView = view
  24.                 } 
  25.             } 
  26.         } 
  27.     } 
  28.  
  29.     CGFloat cellHeight = CGRectGetMaxY(cellBottomView.frame) + bottomOffset; 

其中的cellBottomView是位于cell***部的子視圖,為了提高計算效率***傳入,如果不確定哪個子視圖在最下面,可以傳入一個視圖數組contentViewSubViews,詳細使用方式可以查看demo。

緩存cell高度

高度計算出來后,正常來說我們的需求已經達到了,但是如果這個高度值每次滑動的時候由于cell的復用機制都會重新計算,若果這個cell的自定義樣式很復雜,子視圖太多,那么大量的計算一定會損耗性能而導致明顯的卡頓,所以緩存機制就是個必要的措施,更何況蘋果也建議這樣做;

demo提供了兩個計算行高的API:

 

  1. /** 
  2.  cell自動計算行高 
  3.  
  4.  @param tableView tableView 
  5.  @param indexPath indexPath 
  6.  @param contentViewWidth cell內容寬度,不確定可傳0 
  7.  @return cell高度 
  8.  */ 
  9. + (CGFloat)FSCellHeightForTableView:(UITableView *)tableView indexPath:(NSIndexPath *)indexPath cellContentViewWidth:(CGFloat)contentViewWidth bottomOffset:(CGFloat)bottomOffset; 
  10.  
  11. /** 
  12.  cell自動計算行高優化版 
  13.  
  14.  @param tableView tableView 
  15.  @param indexPath indexPath 
  16.  @param cacheKey 當前cell唯一標識符 
  17.  @param contentViewWidth cell內容寬度,不確定可傳0 
  18.  @return cell高度 
  19.  */ 
  20. + (CGFloat)FSCellHeightForTableView:(UITableView *)tableView indexPath:(NSIndexPath *)indexPath cacheKey:(NSString *)cacheKey cellContentViewWidth:(CGFloat)contentViewWidth bottomOffset:(CGFloat)bottomOffset; 

***種使用數組來做緩存,傳入對應cell的indexPath作為數組索引值;第二種則采用字典來緩存數據,要求傳入一個唯一標識符cacheKey來區分;

兩種方式都可以準確獲得cell高度,***種實現更簡潔,缺點就是數據源發生變化時,所有的緩存就會清空重新計算后緩存,比如reloadData的時候;第二種就是在前者的基礎上添加一個區分不同cell的標識符,使用時還是建議使用第二種,不會清空緩存數據,輕量級頁面沒什么區別??傊畠煞N方法都做了緩存數據的容錯處理,支持以下方法:

 

  1. @selector(reloadData),  
  2. @selector(insertSections:withRowAnimation:),  
  3. @selector(deleteSections:withRowAnimation:),  
  4. @selector(reloadSections:withRowAnimation:),  
  5. @selector(moveSection:toSection:),  
  6. @selector(insertRowsAtIndexPaths:withRowAnimation:),  
  7. @selector(deleteRowsAtIndexPaths:withRowAnimation:),  
  8. @selector(reloadRowsAtIndexPaths:withRowAnimation:),  
  9. @selector(moveRowAtIndexPath:toIndexPath:) 

兼容橫豎屏

這個需求實現較為簡單,就是橫屏和豎屏分別采用兩套緩存數據,互不影響,切換橫豎屏的時候自動切換數據源。

 

  1. - (NSMutableArray *)indexCacheArrForCurrentOrientation  
  2.  
  3. return UIDeviceOrientationIsPortrait([UIDevice currentDevice].orientation) ? self.indexCacheArr_Portrait: self.indexCacheArr_Landscape;  

***實現的效果如圖所示:

iOS自適應cell行高的那點破事兒
FSAutoAdjust-cellHeightDemo. jpg

責任編輯:未麗燕 來源: 簡書
相關推薦

2021-07-30 07:28:15

Kafka消息引擎

2020-01-03 07:57:39

UDPTCP網絡協議

2011-12-26 11:13:24

密碼

2015-12-08 14:49:13

SDN軟件定義網絡

2022-05-26 15:30:21

Spring AOP框架

2011-05-24 16:20:27

虛函數

2022-05-26 09:03:39

AOP編程

2013-12-26 13:35:39

2021-09-30 07:26:15

MQ消息丟失

2017-09-12 08:03:29

數據庫MySQL主庫

2011-12-27 10:18:31

Web

2023-12-04 11:02:53

C++空類

2012-03-12 21:23:47

Windows pho

2013-09-17 10:37:03

AOPAOP教程理解AOP

2018-03-30 16:03:04

軟件無狀態”

2021-04-13 09:12:45

網絡設備無線路由器交換機

2010-05-21 15:34:02

Exchange 20

2009-08-18 17:55:20

C#操作符重載

2019-02-12 11:45:05

Java數據庫開發

2017-06-06 10:30:12

前端Web寬度自適應
點贊
收藏

51CTO技術棧公眾號

影音先锋在线视频| 中文字幕在线天堂| y111111国产精品久久久| 亚洲一区二区av在线| 极品日韩久久| 中文在线字幕av| 欧美一区久久| 亚洲欧洲自拍偷拍| 被黑人猛躁10次高潮视频| 超碰在线97国产| 国产欧美日韩另类视频免费观看| 成人网在线免费看| 4438国产精品一区二区| 久久综合av| 亚洲激情视频在线播放| 天天干天天玩天天操| av3级在线| 国产精品视频你懂的| 国产精品美女久久久久av福利| 亚洲图片欧美日韩| 欧美私人啪啪vps| 一区二区欧美亚洲| 国产成人av无码精品| 巨大黑人极品videos精品| 午夜伦理一区二区| 影音先锋欧美在线| 日韩电影免费| 国产高清成人在线| 国产精品亚洲综合天堂夜夜| 欧美成人精品欧美一级乱黄| 在线成人直播| 一区二区欧美激情| 精品无码在线视频| 一区中文字幕| 日韩一区二区在线播放| 欧美精品无码一区二区三区| 大黄网站在线观看| 亚洲精品国产视频| 久久视频在线直播| 亚洲欧美色图视频| 91蝌蚪精品视频| 91精品国产综合久久国产大片| 国产精品免费成人| 黄在线观看免费网站ktv| 亚洲色图都市小说| 亚洲视频在线二区| 成人在线高清视频| 国产欧美精品在线观看| 欧美一区二区影视| 欧美捆绑视频| 久久日一线二线三线suv| 国产精品亚洲一区| 高潮毛片7777777毛片| 国产乱子轮精品视频| 91在线观看免费高清| 一本色道久久综合无码人妻| 美女视频第一区二区三区免费观看网站| 欧美亚洲一区在线| 中文字幕亚洲高清| 国产欧美精品久久| 欧美在线视频观看| 超碰在线观看91| 免费欧美在线视频| 国产日韩欧美在线观看| 91超薄丝袜肉丝一区二区| 蜜桃免费网站一区二区三区| 国产精品视频精品| 国产精品呻吟久久| 国产精品69毛片高清亚洲| 亚洲字幕在线观看| 日韩一级片免费| 91在线视频播放地址| 欧美另类网站| av网站在线播放| 国产精品久久久久国产精品日日 | 欧美影院在线| 精品卡一卡二卡三卡四在线| 99久久久无码国产精品性波多| 国产精品18hdxxxⅹ在线| 亚洲精品电影网站| 四虎国产精品成人免费入口| 国内精品久久久久久久影视简单| 永久免费精品影视网站| 欧美成人黄色网| 亚洲精品专区| 国产精品无av码在线观看| 国产毛片在线视频| av毛片久久久久**hd| 日韩av大全| 中文字幕资源网在线观看| 亚洲超碰97人人做人人爱| 欧美 日韩 国产 激情| 综合欧美精品| 亚洲精品国产美女| 中国1级黄色片| 欧美午夜不卡影院在线观看完整版免费| 久久久久久久国产精品视频| 日本视频在线观看免费| 国产尤物一区二区在线| 精品视频一区二区| 里番在线观看网站| 精品国产31久久久久久| 亚洲免费一级视频| 欧美大胆a级| 日韩中文视频免费在线观看| 久久精品美女视频| 欧美aaa在线| 九色91在线视频| 香蕉视频在线免费看| 午夜激情综合网| www,av在线| 国产精品一区二区av交换| 欧美肥婆姓交大片| 曰批又黄又爽免费视频| 99久久综合99久久综合网站| 9999在线观看| 日日av拍夜夜添久久免费| 日韩美女主播在线视频一区二区三区 | 日本不卡1234视频| 日韩欧美精品在线视频| 一级黄色性视频| 亚洲天堂激情| 成人中心免费视频| 成人影视在线播放| 欧美日韩亚洲一区二区| 免费欧美一级片| 欧美丝袜一区| 日本在线观看天堂男亚洲| 亚洲精品视频专区| 亚洲欧美一区二区三区孕妇| 亚洲视频在线a| 亚洲va久久久噜噜噜久久| 久久99亚洲热视| 国产999久久久| 国产精品美女久久久久久久久久久| 欧美a在线视频| 风间由美性色一区二区三区四区 | 日本欧美一区二区在线观看| 久久精品日产第一区二区三区乱码 | 久久久久久日产精品| 九一国产精品视频| 成人中文字幕视频| 欧美激情一区二区三区在线视频观看 | 国产日韩二区| 欧美韩日亚洲| 日韩一区二区高清| 丁香花五月激情| 麻豆视频一区二区| 天堂精品一区二区三区| 成人久久网站| www.欧美三级电影.com| 在线观看免费高清视频| 国产精品卡一卡二| 九九热精品在线播放| 93在线视频精品免费观看| 国产精品视频成人| 日本高清中文字幕在线| 欧美高清精品3d| 欧美 日韩 国产 一区二区三区| 久久精品国产77777蜜臀| 亚洲一区二区不卡视频| 久久国内精品| 欧美成人精品在线| 丰满人妻一区二区三区无码av | 中文字幕日韩一区二区三区| 亚洲香蕉久久| 久久6精品影院| 日韩中文字幕影院| 色一情一乱一乱一91av| 欧美激情亚洲色图| 经典三级在线一区| 艳母动漫在线观看| 久久97久久97精品免视看秋霞| 午夜剧场成人观在线视频免费观看| 姝姝窝人体www聚色窝| 欧美视频在线免费看| www.99热| 国产精品99久久久| 欧美 日韩 国产在线观看| 久久av中文| 91精品国自产在线观看| а√天堂8资源在线| 怡红院精品视频| 国产黄色美女视频| 一本色道久久综合亚洲aⅴ蜜桃| 亚洲最大成人综合网| 国产一区二区免费视频| 霍思燕三级露全乳照| 国产成人久久| 亚洲xxxxx性| 欧美专区福利免费| 欧美xxxx14xxxxx性爽| 婷婷色在线观看| 欧美性高清videossexo| 麻豆91精品91久久久| 久久久久久久久久久电影| 亚洲天堂网站在线| 亚洲欧美不卡| 国产成人三级视频| 香蕉久久夜色精品国产更新时间 | 国产片高清在线观看| 亚洲成a天堂v人片| 国产一二三四视频| 91在线播放网址| 三级黄色片播放| 日韩精品色哟哟| 欧美乱做爰xxxⅹ久久久| 精品国产一区一区二区三亚瑟| 亚洲tv在线观看| 羞羞影院欧美| 久久久视频在线| 日本视频在线免费观看| 亚洲免费视频一区二区| 超碰人人人人人人| 欧美日本在线观看| 亚洲精品中文字幕乱码三区91| 亚洲欧美二区三区| avhd101老司机| 99国产精品99久久久久久| 四川一级毛毛片| 久久亚洲高清| 激情久久一区二区| 国内成人精品视频| 国产调教视频在线观看| 亚洲色图25p| 蜜臀久久99精品久久久| 9191久久久久久久久久久| 亚洲 欧美 成人| 久久99青青| 欧美午夜电影在线| 26uuu成人网| 中文字幕 久热精品 视频在线| 国产在线不卡av| 国产精品99久久久久| 国产传媒免费观看| 欧美aaa在线| 午夜视频在线瓜伦| 久久久青草婷婷精品综合日韩 | 亚洲午夜精品一区 二区 三区| 欧洲亚洲一区二区| 香蕉视频一区二区三区| 国产综合第一页| 国产精品45p| 国产日韩欧美精品| 91精品国产自产精品男人的天堂| 91午夜理伦私人影院| 亚洲精品aa| 成人www视频在线观看| 精品久久福利| 国产在线精品自拍| 成人精品在线| 亚洲a在线播放| 国产亚洲久久| 97人人干人人| aaa国产精品视频| 国产精品久久久久久久天堂第1集| 亚洲精品影片| 国产日韩在线一区二区三区| 欧美18xxxx| 蜜桃av噜噜一区二区三区| 久9久9色综合| 亚洲高清在线播放| 无码一区二区三区视频| 热久久最新地址| 亚洲激情网站| 欧美成人精品欧美一级乱| 久久综合九色综合欧美狠狠| caopor在线视频| 久久99久久精品| 欧美性猛交乱大交| 99精品视频在线观看| 国产jjizz一区二区三区视频| 国产色综合一区| 国产麻豆视频在线观看| 一区二区三区四区五区视频在线观看| 久久精品一区二区三| 精品国产999| 进去里视频在线观看| 欧美一区二区三区免费观看视频 | 国产精品一区一区| 丰满岳乱妇一区二区| 久久综合狠狠综合久久综合88| 久久久久亚洲av无码a片| 亚洲蜜臀av乱码久久精品| 国产精品6666| 在线观看日韩毛片| 性猛交富婆╳xxx乱大交天津| 亚洲国产黄色片| 91精彩视频在线观看| 欧美麻豆久久久久久中文| 欧美aa在线| 国产综合视频在线观看| 国内精品免费| 亚洲永久一区二区三区在线| 欧美午夜不卡| 欧美一级特黄a| 国产91精品精华液一区二区三区 | 美女久久久久| 特级黄色录像片| 久久蜜桃精品| 乳色吐息在线观看| 日本一区二区久久| 日韩av男人天堂| 91精选在线观看| 国产最新视频在线| 欧美高清视频一区二区| 播放一区二区| 精品欧美国产| 欧美国产91| 日本 片 成人 在线| 不卡免费追剧大全电视剧网站| jizz18女人高潮| 欧美性20hd另类| 开心激情综合网| 日韩日本欧美亚洲| 人人鲁人人莫人人爱精品| 国产精品免费看一区二区三区| 久久综合成人| 国产熟女高潮视频| 成人黄色在线看| 欧美日韩在线视频免费播放| 欧洲亚洲国产日韩| 神马久久精品| 久久久久久久久中文字幕| 国模大尺度视频一区二区| 亚洲国产精品久久久久久女王| 国产日韩精品视频一区二区三区| 久久久国产精品久久久| 国产精品久久久久aaaa樱花 | 美女在线观看视频一区二区| 在线视频 日韩| 亚洲一卡二卡三卡四卡五卡| 91禁在线观看| 中文字幕日韩欧美精品在线观看| 电影一区二区三| 久久久神马电影| 亚洲国产精品一区| 蜜桃色一区二区三区| 一区二区三区日韩欧美精品 | 国产一区二区电影| 人人干在线观看| 欧美精选一区二区| 日本在线视频站| 国产精品亚洲网站| 波多野结衣在线观看一区二区三区 | 欧美性xxxxxxxx| 第三区美女视频在线| 国产成人啪精品视频免费网| 无码少妇一区二区三区| 无码人妻丰满熟妇区毛片18| 91网页版在线| 亚洲欧美偷拍一区| 国产午夜精品视频免费不卡69堂| av电影一区| 欧洲一区二区日韩在线视频观看免费| 久久性色av| 久久精品色妇熟妇丰满人妻| 欧美日韩极品在线观看一区| 成人video亚洲精品| 99视频免费观看蜜桃视频| 欧美日韩国产精品一区二区亚洲| 日本少妇xxx| 午夜精品在线视频一区| 日色在线视频| 国产精品久久久久久久久久尿 | 成人国产亚洲欧美成人综合网| 日本熟女一区二区| 亚洲老头同性xxxxx| 朝桐光一区二区| 日本一级淫片演员| 成人一区二区视频| 欧美videossex极品| 在线亚洲欧美视频| 国产精品一区二区三区av| 妞干网视频在线观看| 99国产欧美另类久久久精品| 在线观看亚洲黄色| 久久韩国免费视频| 99精品国产一区二区三区2021| 无码精品a∨在线观看中文| 中文字幕精品—区二区四季| 精品国产乱码一区二区三| 午夜精品免费视频| 日韩www.| 中文视频在线观看| 欧美中文字幕一区| 香蕉成人app免费看片| 免费电影一区| 久久99精品一区二区三区| 免费日韩在线视频| 亚洲天堂开心观看| 国产精品一区二区三区四区在线观看| 国产真人做爰毛片视频直播| 国产色产综合色产在线视频 | 国产激情精品久久久第一区二区| 国产第100页| www国产精品视频| 秋霞蜜臀av久久电影网免费| 男人的天堂最新网址| 天天综合网 天天综合色|