iOS開發之UITableView使用總結

來源:互聯網
上載者:User

標籤:

什麼是UITableView
  1. 在眾多行動裝置 App中,能看到各式各樣的表格式資料
  2. 在iOS中,要實現表格式資料展示,最常用的做法就是使用UITableView
  3. UITableView繼承自UIScrollView,因此支援垂直滾動,而且效能極佳

UITableView的兩種樣式

    •   UITableViewStylePlain

    •   UITableViewStyleGrouped

tableView展示資料的過程

  1.調用資料來源的下面方法得知一共有多少組資料
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView;
  2.調用資料來源的下面方法得知每一組有多少行資料
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section;
  3.調用資料來源的下面方法得知每一行顯示什麼內容
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath;

Cell簡介

  1. UITableView的每一行都是一個UITableViewCell,通過dataSource的tableView:cellForRowAtIndexPath:方法來初始化每一行
  2. UITableViewCell內部有個預設的子視圖:contentView,contentView是UITableViewCell所顯示內容的父視圖,可顯示一些輔助指示視圖。輔助指示視圖的作用是顯示一個表示動作的表徵圖,可以通過設定UITableViewCell的accessoryType來顯示,預設是UITableViewCellAccessoryNone(不顯示輔助指示視圖),其他值如下:
  3. 還可以通過cell的accessoryView屬性來自訂輔助指示視圖(比如往右邊放一個開關)

UITableViewCell的contentView

  contentView下預設有3個子視圖,其中2個是UILabel(通過UITableViewCell的textLabel和detailTextLabel屬性訪問),第3個是UIImageView(通過UITableViewCell的imageView屬性訪問)。UITableViewCell還有一個UITableViewCellStyle屬性,用於決定使用contentView的哪些子視圖,以及這些子視圖在contentView中的位置。列出UITableViewCellStyle的值以及顯示樣式: UITableViewCell結構圖  Cell的重用原理  iOS裝置的記憶體有限,如果用UITableView顯示成千上萬條資料,就需要成千上萬個UITableViewCell對象的話,那將會耗盡iOS裝置的記憶體。要解決該問題,需要重用UITableViewCell對象。  重用原理:當滾動列表時,部分UITableViewCell會移出視窗,UITableView會將視窗外的UITableViewCell放入一個對象池中,等待重用。當UITableView要求dataSource返回UITableViewCell時,dataSource會先查看這個對象池,如果池中有未使用的UITableViewCell,dataSource會用新的資料配置這個UITableViewCell,然後返回給UITableView,重新顯示到視窗中,從而避免建立新對象。  還有一個非常重要的問題:有時候需要自訂UITableViewCell(用一個子類繼承UITableViewCell),而且每一行用的不一定是同一種UITableViewCell,所以一個UITableView可能擁有不同類型的UITableViewCell,對象池中也會有很多不同類型的UITableViewCell,那麼UITableView在重用UITableViewCell時可能會得到錯誤類型的UITableViewCell  解決方案:UITableViewCell有個NSString *reuseIdentifier屬性,可以在初始化UITableViewCell的時候傳入一個特定的字串標識來設定reuseIdentifier(一般用UITableViewCell的類名)。當UITableView要求dataSource返回UITableViewCell時,先通過一個字串標識到對象池中尋找對應類型的UITableViewCell對象,如果有,就重用,如果沒有,就傳入這個字串標識來初始化一個UITableViewCell對象 Cell的重用代碼
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{    // 1.定義一個cell的標識      static NSString *ID = @"mjcell";        // 2.從緩衝池中取出cell      UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];        // 3.如果緩衝池中沒有cell      if (cell == nil) {        cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:ID];    }        // 4.設定cell的屬性...    return cell;}

自訂cell

  • 通過xib自訂view的方式自訂cell的步驟
    1.建立一個xib檔案描述一個view的內部結構(假設叫做HooCell.xib)    2.建立一個自訂的類(自訂類需要繼承自系統內建的UITableViewCell或者子類, 繼承自哪個類,  取決於xib根對象的Class)    3.建立類的類名最好跟xib的檔案名稱保持一致(比如類名就叫做HooCell)    4.將xib中的控制項 和 自訂類的.m檔案 進行連線    5.提供一個類方法返回一個建立好的自訂view(屏蔽從xib載入的過程)    6.提供一個模型屬性讓外界傳遞模型資料    7.重寫模型屬性的setter方法,在這裡將模型資料展示到對應的子控制項上面
  • 通過代碼自訂cell的步驟(MVVM)

    1.建立一個繼承自UITableViewCell的類

    2.重寫initWithStyle:reuseIdentifier:方法

      • 添加所有需要顯示的子控制項(不需要設定子控制項的資料和frame,  子控制項要添加到contentView中)
      • 進行子控制項一次性的屬性設定(有些屬性只需要設定一次, 比如字型\固定的圖片)

    3.提供2個模型

      • 資料模型: 存放文字資料\圖片資料
      • frame模型: 存放資料模型\所有子控制項的frame\cell的高度

    4.cell擁有一個frame模型(不要直接擁有資料模型) 

    5.重寫frame模型屬性的setter方法: 在這個方法中設定子控制項的顯示資料和frame

    6.frame模型資料的初始化已經採取懶載入的方式(每一個cell對應的frame模型資料只載入一次)

iOS開發之UITableView使用總結

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.