精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

中文字幕一区二区三区四区五区 | 免费在线国产| 日韩精品成人一区二区在线| 最近2019中文字幕一页二页| 永久免费看片在线观看| sm久久捆绑调教精品一区| 2023国产一二三区日本精品2022| 国产精品网站视频| 国产无码精品视频| 日本不卡免费一区| 亚洲第一区中文99精品| 777视频在线| 国产夫妻在线播放| 亚洲青青青在线视频| 欧美日韩国产精品一区二区| 国产精品久久久久毛片| a91a精品视频在线观看| 久久精品久久久久久国产 免费| 妖精视频一区二区| 不卡一区视频| 在线观看亚洲a| 日本一区午夜艳熟免费| 欧美成年黄网站色视频| 91美女片黄在线观看| 99r国产精品视频| 成人免费一区二区三区| 99精品视频免费| 欧美成人精品一区二区三区| 欧美激情视频二区| 色橹橹欧美在线观看视频高清| 日韩一级片网址| 亚欧在线免费观看| 中老年在线免费视频| 一区二区三区日韩欧美精品| 亚洲精品人成| 国产永久免费高清在线观看 | 黄色录像a级片| 免费精品一区二区三区在线观看| 精品视频1区2区| 国产午夜福利视频在线观看| 888av在线视频| 亚洲精品日韩综合观看成人91| 亚洲午夜精品一区二区| 欧美在线观看在线观看| 北岛玲一区二区三区四区| 91久久国产自产拍夜夜嗨| 91在线精品入口| 免费在线观看精品| 国产美女精品视频| 中国精品一区二区| 青草av.久久免费一区| 国产成人福利视频| 中文字幕精品视频在线观看| 国产亚洲毛片在线| 668精品在线视频| 日韩av在线电影| 亚洲人成在线影院| 91国语精品自产拍在线观看性色| 精品一区免费观看| 在线欧美不卡| 91禁外国网站| 久久亚洲精品石原莉奈| 麻豆成人在线| 国产精品中文久久久久久久| 在线观看免费视频a| 久久99国产精品久久99果冻传媒| 91精品久久久久久久久久入口 | 伊人网在线播放| 精品女厕一区二区三区| 亚洲成熟丰满熟妇高潮xxxxx| 在线观看的黄色| 在线精品视频免费观看| 色国产在线视频| 精品视频在线观看免费观看| 日韩欧美综合在线| 小毛片在线观看| 免费成人结看片| 深夜福利一区二区| 久草免费在线观看视频| 日韩一区二区久久| 国产精品高潮在线| 97成人在线观看| 丁香婷婷综合激情五月色| 久久国产精品一区二区三区四区| 日本福利片在线| 国产精品盗摄一区二区三区| 奇米777四色影视在线看| 国产精品电影| 欧美色窝79yyyycom| 巨乳女教师的诱惑| 亚洲欧美成人vr| 久久久精品亚洲| 国产高潮失禁喷水爽到抽搐| av一本久道久久波多野结衣| 欧美久久婷婷综合色| 99久久精品费精品国产一区二区| 国模吧精品视频| 日本不卡网站| 免费观看国产视频| 国产真实乱偷精品视频| 亚洲成年人专区| 欧美人妻精品一区二区免费看| 欧美日韩精品一本二本三本| 97在线视频国产| 亚洲高清在线看| 国产91精品入口| 日韩欧美一区二区三区久久婷婷| 日韩精品亚洲人成在线观看| 色天天综合久久久久综合片| 波多野结衣电影免费观看| 欧美美女在线| 欧美日本中文字幕| 久久久久久av无码免费看大片| 国产精品一品视频| 亚洲精品一区二| 在线视频cao| 亚洲成人网av| 国产尤物在线播放| 日日夜夜一区二区| 国产乱码精品一区二区三区卡| 亚洲1卡2卡3卡4卡乱码精品| 欧美日韩性视频在线| 中文字幕一二三| 久久久久蜜桃| 国产精品日韩在线播放| 婷婷在线观看视频| 亚洲午夜国产一区99re久久| 日韩欧美亚洲另类| 成人女性视频| 国产福利精品视频| 丝袜视频国产在线播放| 亚洲成人激情av| 日韩大尺度视频| 综合一区av| 成人福利在线视频| 亚洲1卡2卡3卡4卡乱码精品| 91黄色免费网站| 91中文字幕永久在线| 在线综合亚洲| 好吊色欧美一区二区三区| 欧美精品videosex| 欧美一级高清片在线观看| 欧美一区二区三区观看| 日本不卡在线视频| 色涩成人影视在线播放| 深夜成人福利| 一本色道久久88精品综合| 中文字幕在线看人| 久久精品一区二区三区不卡牛牛| 国产精品亚洲a| 国产精品嫩草影院在线看| 日本精品性网站在线观看| 神马电影在线观看| 亚洲国产你懂的| 一级特级黄色片| 国产日韩专区| 日本黑人久久| 电影在线观看一区二区| 一区二区成人av| 亚洲手机在线观看| 亚洲欧美日本在线| 三级网站免费看| 亚洲小说区图片区| 久久99国产精品| 婷婷激情一区| 色系列之999| 国产日韩免费视频| 香港成人在线视频| 黑人巨大精品欧美| 麻豆免费精品视频| 色哺乳xxxxhd奶水米仓惠香| 亚洲三区欧美一区国产二区| 91精品国产91久久久久福利| 能在线看的av| 欧美日韩日日摸| 久久黄色小视频| 91丨九色丨蝌蚪丨老版| 天天爽天天爽夜夜爽| 亚洲综合激情在线| 精品无码久久久久国产| 欧美最新精品| 欧美巨猛xxxx猛交黑人97人| 日本久久一级片| 欧美无乱码久久久免费午夜一区| 国产高潮流白浆| 91网站最新网址| 99re6在线观看| 亚洲日本免费| 亚洲人成人77777线观看| 亚洲国产中文在线| 国产精品69av| 天堂8中文在线| 国产亚洲xxx| 国模私拍视频在线| 欧美体内she精视频| 久久伊人成人网| 欧美国产精品专区| 亚洲精品激情视频| 秋霞影院一区二区| 成人免费视频91| 久久人体视频| 蜜桃久久精品乱码一区二区 | 精品福利久久久| 7777精品久久久大香线蕉小说| 中文在线免费二区三区| 久久成人精品视频| 国产精品一级伦理| 亚洲精品一区二区三区蜜桃下载 | 青青草视频国产| 欧美日韩第一| 国产精品日韩欧美一区二区三区| 国产一区高清| 欧美在线视频播放| 久久久久黄久久免费漫画| 综合国产在线观看| 青青草娱乐在线| 欧美r级在线观看| 一本色道久久综合熟妇| 91精品办公室少妇高潮对白| 日本少妇毛茸茸高潮| 亚洲美女视频一区| 欧美a级片免费看| 国产日韩亚洲欧美综合| 国产国语性生话播放| 国产成人h网站| 一二三级黄色片| 六月婷婷色综合| 久久精品一区二| 国产精品毛片一区二区三区| 日韩a级黄色片| 欧美在线影院| 91精品一区二区三区四区| 大片网站久久| 日韩精品一区二区三区四区五区| 天天躁日日躁狠狠躁欧美| 国产精品二区三区| 18国产精品| 产国精品偷在线| 精品国产伦一区二区三区观看说明| 国产精品视频网站| 久久99国产精品二区高清软件| 日本高清久久天堂| 92国产精品| 日韩av电影院| 色成人免费网站| 国产精品久久久久久久久久新婚| 欧美xxx性| 国产精品成人播放| 欧美日韩尤物久久| 国产精品专区h在线观看| 全球中文成人在线| 成人欧美一区二区三区黑人孕妇 | 婷婷丁香综合网| 中文字幕av一区二区三区| 又色又爽的视频| 亚洲视频免费在线观看| 在线观看亚洲网站| 夜夜嗨av一区二区三区中文字幕| 久久久精品国产sm调教网站| 亚洲成人免费视| 久久精品一二区| 在线免费观看视频一区| 亚洲精品国产精品国自产网站按摩| 欧洲精品在线观看| 国产精品色综合| 精品国产乱码久久久久久影片| 神宫寺奈绪一区二区三区| 亚洲精品久久7777777| 国产中文在线观看| 日韩在线免费观看视频| av中文字幕在线播放| 亚州成人av在线| 97欧美成人| 亚洲一区二区三区视频| 玖玖玖免费嫩草在线影院一区| 欧美日韩国产免费一区二区三区 | xxav国产精品美女主播| 91蜜桃在线视频| 欧美亚洲国产日本| 成人黄色免费网站| 99中文字幕| 欧美久久综合网| 青青在线视频免费观看| 久久av最新网址| 99九九99九九九99九他书对| 成人激情免费电影网址| 国产人妻大战黑人20p| 亚洲视频精选在线| 99久在线精品99re8热| 欧美亚洲一区二区三区四区| 精品黑人一区二区三区在线观看| 日韩av在线免费观看一区| 欧美猛烈性xbxbxbxb| 国内偷自视频区视频综合| 四虎地址8848精品| 久久精品国产综合精品| 婷婷精品进入| 日韩精品一区二区三区不卡| 国产毛片精品一区| 欧美熟妇激情一区二区三区| 一区二区三区精品视频| 黄色一区二区视频| 亚洲精品电影在线观看| 国产激情视频在线观看| 国产不卡av在线| 精品自拍偷拍| 黄色污污在线观看| 日本强好片久久久久久aaa| 亚洲婷婷在线观看| 最新热久久免费视频| 中文字幕一区二区三区四区欧美| 日韩情涩欧美日韩视频| av男人的天堂在线| 欧美又大又粗又长| 91精品久久久久久综合五月天| 一级日韩一区在线观看| 麻豆精品网站| 日b视频在线观看| 一区二区欧美国产| 国产精品一区二区av白丝下载 | 中文字幕中文字幕在线中高清免费版| 日本精品一区二区三区在线播放视频 | 国产原创剧情av| 亚洲乱码国产乱码精品精98午夜 | 久久激情综合网| 中文字幕第4页| 狠狠爱在线视频一区| 丁香花免费高清完整在线播放| 欧美成人精品在线视频| 色8久久久久| 一区二区三区四区| 日本中文字幕一区二区有限公司| 成人免费av片| 欧美日韩中文字幕| 少妇一级淫片免费看| 久久理论片午夜琪琪电影网| 国产中文欧美日韩在线| 中文字幕不卡每日更新1区2区| 男女激情视频一区| 欧美另类69xxxx| 欧美日韩在线免费视频| 香蕉视频国产在线观看| 国产精品免费福利| 国产探花在线精品| 亚洲色图38p| 国产精品午夜春色av| 中文天堂在线资源| 日韩综合中文字幕| 成人在线分类| 日本男女交配视频| 菠萝蜜视频在线观看一区| 欧美激情亚洲综合| 亚洲欧美日韩视频一区| 向日葵视频成人app网址| 天堂资源在线亚洲资源| 美女高潮久久久| 午夜爽爽爽男女免费观看| 精品欧美黑人一区二区三区| 97在线超碰| 欧美激情第一页在线观看| 水野朝阳av一区二区三区| 在线看片中文字幕| 4438成人网| 欧美人与动牲性行为| 精品免费国产| 日本不卡一区二区三区| 小泽玛利亚一区| 精品美女在线播放| 91久久国产综合久久91猫猫| 亚洲欧美丝袜| 国产福利一区二区三区视频| 日本中文字幕网| 在线精品视频视频中文字幕| 国产精品成人**免费视频| 国内精品视频一区二区三区| 2024国产精品| 国产女人高潮的av毛片| 欧美激情国产精品| 国产精品一区高清| 肉色超薄丝袜脚交| 精品国产老师黑色丝袜高跟鞋| 国产一级在线| 91精品国自产在线观看| 午夜在线a亚洲v天堂网2018| 精品在线观看一区| 亚洲国产第一页| 久久av影院| 黄色大片在线免费看| 国产欧美精品一区| www日本视频| 日产精品99久久久久久| 亚洲字幕久久| www.狠狠爱| 精品国产乱码久久久久久久| 日本一区二区电影| 久久亚洲中文字幕无码| 亚洲欧美一区二区视频| 四虎国产精品永远| 成人国产1314www色视频| 蜜臀精品久久久久久蜜臀|