UITableViewCell高度自適應的關鍵點,ioscell高度自適應

來源:互聯網
上載者:User

UITableViewCell高度自適應的關鍵點,ioscell高度自適應

iOS開發中對於UITableViewCell高度自適應的文章已經很多很多,但如果cell內容比較複雜,剛使用autolayout配置自使用時還是總不能一次性成功。

KEY POINT

這裡只說設定的關鍵一點:

Cell內部的Constraints一定要有一條從Cell頂部到底部的一條可聯通線。

圖例列表:


Paste_Image.png
Paste_Image.png
Paste_Image.png

最後頂部元素居上和底部元素距底部,加上約束即可。
這條線上可以有固定高度的元素,可以有自適應高度的元素,但要保證:

設定自適應高度的元素都在這條線上。

當然如果在同一水平上有兩個需要自適應高度的元素,就有擇其一了。

OTHER POINTS

其他注意要點:


Paste_Image.pngLAST

最後在代碼檔案中,添加代碼:
iOS8
使用iOS8新出的方法:

self.tableView.estimatedRowHeight=44;self.tableView.rowHeight=UITableViewAutomaticDimension;

iOS7
(就讓iOS7丟棄在曆史中吧。)
ios中沒有UITableViewAutomaticDimension自動計算高度,就只能自己去計算了。
ios7中需要一個輔助cell,cell的內容和UITableView的內容一致,但不用於顯示,而是用於根據填充的內容計算每個cell的高度。

@property (strong,nonatomic) AdaptionCell *adaptionCell;
//-(void)viewDidLoad 這裡為什麼不能使用[tableView dequeueReusableCellWithIdentifier:cellIdentifier forIndexPath:indexPath]設定一個cell。因為這會導致cell被建立了但是又未曾被tableView:cellForRowAtIndexPath:方法返回,會造成記憶體泄露。self.adaptionCell = [cellNib instantiateWithOwner:nil options:nil][0];
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath{ self.adaptionCell.contentLabel.text=self.dataArray[indexPath.row%2];    [self.adaptionCell layoutIfNeeded];    CGFloat height = [self.adaptionCell.contentView systemLayoutSizeFittingSize:UILayoutFittingCompressedSize].height;    return height+1;}

這裡為什麼要+1,因為UITableViewCell有個邊緣線,比其ContentView高1(其實應該是0.5)

上面的方法裡使用的一個函數systemLayoutSizeFittingSize擷取contentView的size,最終得到一個自適應後的height。

但這裡有個問題---為什麼這個方法得到了一個自適應的height,而不一個自適應的Width!
所以應該有個地方來限定Width,使得Cell的內容的填充是在縱向上,而不是橫向。

//  AdaptionCell.m- (void)layoutSubviews{    [super layoutSubviews];    [self.contentView layoutIfNeeded];    self.contentLabel.preferredMaxLayoutWidth = CGRectGetWidth(self.contentLabel.frame);}
LAST LAST

最後的最後,附上結果圖:


Paste_Image.png

和一個問題:
如果cell中需要自適應高度的文本是富文本,是否還可以使用autolayout做自適應?
簡單的UILabel attributedText可以通過



作者:Seas
連結:http://www.jianshu.com/p/386b792054b1
來源:簡書
著作權歸作者所有。商業轉載請聯絡作者獲得授權,非商業轉載請註明出處。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.