iOS學(xué)習(xí)之 UITableVIew cell 創(chuàng)建方式(XIB, storyboard)

UITableView

  • 數(shù)據(jù)源的常用方法

  • 此方法設(shè)置 cell 的組數(shù)
    - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView;

  • 每一組有多少行數(shù)據(jù)
    - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section;

  • 每一行顯示什么內(nèi)容梢夯,返回 cell
    - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath;

  • 設(shè)置每一組的頭部信息
    - (NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section;

  • 設(shè)置每一組的尾部信息
    - (NSString *)tableView:(UITableView *)tableView titleForFooterInSection:(NSInteger)section

  • tabelView常見屬性

    // 設(shè)置每一行cell的高度
    self.tableView.rowHeight = 100;
    
    // 設(shè)置每一組頭部的高度
    self.tableView.sectionHeaderHeight = 50;
    // 設(shè)置每一組尾部的高度
    self.tableView.sectionFooterHeight = 50;
    // 設(shè)置分割線顏色
    self.tableView.separatorColor = [UIColor redColor];
    // 設(shè)置分割線樣式
    self.tableView.separatorStyle = UITableViewCellSeparatorStyleNone;
    // 設(shè)置表頭控件
    self.tableView.tableHeaderView = [[UISwitch alloc] init];
    // 設(shè)置表尾控件
    self.tableView.tableFooterView = [UIButton buttonWithType:UIButtonTypeContactAdd];
    // 設(shè)置右邊索引文字的顏色
    self.tableView.sectionIndexColor = [UIColor redColor];
    // 設(shè)置右邊索引文字的背景色
    self.tableView.sectionIndexBackgroundColor = [UIColor blackColor];
    
    
  • cell

  • UITableView的每一行都是一個(gè)UITableViewCell痊乾,通過dataSource的tableView:cellForRowAtIndexPath:方法來初始化每一行

  • UITableViewCell內(nèi)部有個(gè)默認(rèn)的子視圖:contentView,contentView是UITableViewCell所顯示內(nèi)容的父視圖霍弹,可顯示一些輔助指示視圖

  • 輔助指示視圖的作用是顯示一個(gè)表示動(dòng)作的圖標(biāo)绕沈,可以通過設(shè)置UITableViewCell的accessoryType來顯示篮绿,默認(rèn)是UITableViewCellAccessoryNone(不顯示輔助指示視圖)

  • 可以通過cell的accessoryView屬性來自定義輔助指示視圖(比如往右邊放一個(gè)開關(guān))

  • 傳統(tǒng)的寫法

    /**
    *  每當(dāng)有一個(gè)cell要進(jìn)入視野范圍內(nèi)纹份,就會(huì)調(diào)用一次
    */
    - (UITableViewCell *)tableView:(UITableView *)tableView cell ForRowAtIndexPath:(NSIndexPath *)indexPath
    {
    static NSString *ID = @"wine";
    
    // 1.先去緩存池中查找可循環(huán)利用的cell
    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];
    
    // 2.如果緩存池中沒有可循環(huán)利用的cell
    if (!cell) {
        cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:ID];
    }
    
    // 3.設(shè)置數(shù)據(jù)
    cell.textLabel.text = [NSString stringWithFormat:@"%zd行的數(shù)據(jù)", indexPath.row];
    
    return cell;
    

}
```

  • 新的寫法(注冊(cè)cell)

    NSString *ID = @"wine";
    
    - (void)viewDidLoad {
    [super viewDidLoad];
    
    // 注冊(cè)某個(gè)重用標(biāo)識(shí) 對(duì)應(yīng)的 Cell類型
    [self.tableView registerClass:[UITableViewCell class] forCellReuseIdentifier:ID];
    }
    - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
    

{
// 1.先去緩存池中查找可循環(huán)利用的cell
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];

// 2.設(shè)置數(shù)據(jù)
cell.textLabel.text = [NSString stringWithFormat:@"%zd行的數(shù)據(jù)", indexPath.row];

return cell;

}
```

  • 自定義 cell

  • 等高 cell 代碼

    1. 新建一個(gè)繼承自UITableViewCell的子類
    2. 重寫新建子類的-initWithStyle:reuseIdentifier:方法在這個(gè)方法中添加所有需要顯示的子控件。給子控件做一些初始化設(shè)置(設(shè)置字體旗们、文字顏色等)
    3. 重寫-layoutSubviews方法一定要調(diào)用[superlayoutSubviews]在這個(gè)方法中計(jì)算和設(shè)置所有子控件的frame
    4. 提供模型屬性,設(shè)置模型的數(shù)據(jù)构灸,在 set 方法中
    5. 注冊(cè) cell上渴。。喜颁。下面方法是從 xib 中 zuce
      [self.tableView registerNib:[UINib             
                   nibWithNibName:NSStringFromClass([MTTgCell class]) 
                           bundle:nil] 
                           forCellReuseIdentifier:ID];
      
  • 不等高 cell

    1. 在模型內(nèi)部提供可設(shè)置 cell高度 的的 frame屬性稠氮,
        @interface XMGStatus : NSObject
        @property (nonatomic, assign) CGRect iconFrame;
        /** cell的高度 */
        @property (nonatomic, assign) CGFloat cellHeight;
        @end
    
    1. model.m中重寫模型cellHeight屬性的get方法

      - (CGFloat)cellHeight
      {
          if (_cellHeight == 0) {
              // ... 計(jì)算所有子控件的frame、cell的高度
          }
          return _cellHeight;
      }
      
    2. 在控制器中實(shí)現(xiàn)返回 cell 高度的代理方法半开,heightforrow

          // 返回每一行cell的具體高度
          - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
          {
          SBStatus *status = self.statuses[indexPath.row];
          return status.cellHeight;
          }
      
    3. 給 cell 模型傳值

    4. 新建一個(gè)繼承自UITableViewCell的子類隔披,比如SBStatusCell,并且提供一個(gè)模型屬性

    5. 在SBStatusCell.m中重寫模型屬性的set方法

  • 文字尺寸的計(jì)算

    • 計(jì)算文字所占據(jù)的尺寸
        NSDictionary *nameAttrs = @{NSFontAttributeName : [UIFont systemFontOfSize:17]};
        CGSize nameSize = [self.name sizeWithAttributes:nameAttrs];
    
    • 計(jì)算一段文字的尺寸
        CGSize textMaxSize = CGSizeMake(textW, MAXFLOAT);
        NSDictionary *textAttrs = @{NSFontAttributeName : [UIFont systemFontOfSize:14]};
        CGFloat textH = [self.text boundingRectWithSize:textMaxSize
                                                options:NSStringDrawingUsesLineFragmentOrigin 
                                             attributes:textAttrs 
                                                context:nil].size.height;
    
    
    • 計(jì)算屏幕的寬
      • [UIScreen mainScreen].bounds.size.width
  • 連線修改約束
    • 定義一個(gè)高度約束且連線到 storyboard
      • @property (nonatomic, weak) IBOutlet NSLayoutConstraint *picHeight;
    • 然后在模型設(shè)置控件的 set 方法中修改
      • self.picHeight.constant = 100;
  • cellheight 不等高的估算和自動(dòng)計(jì)算
    • 程序一開始就會(huì)吧 tabelViewl 的所有cell高度算出來寂拆,確定 contengSize 的大小奢米,從而計(jì)算出滾動(dòng)條的長(zhǎng)度。所以這樣的性能不好纠永,所以蘋果推出了估算高度鬓长。
    • 告訴tabelview的 cell的估算高度,就可以使heightforrow方法的調(diào)用次數(shù)減少
    • 設(shè)置估算的方法
      1. self.tabelView.estimateRowHeight = 10
      2. - (CGFloat)tableView:(UITableView *)tableView estimatedHeightForRowAtIndexPath:(NSIndexPath *)indexPath 通過代理方法
    • 處理不等高 cell 自動(dòng)計(jì)算(iOS8開始才支持)
      1. 告訴tableView所有cell的真實(shí)高度是自動(dòng)計(jì)算(根據(jù)設(shè)置的約束來計(jì)算)
        self.tableView.rowHeight = UITableViewAutomaticDimension;
      2. 告訴tableView所有cell的估算高度. self.tableView.estimatedRowHeight = 44;
      3. 這種需要設(shè)置約束連線尝江,然后在 cell 的 setModel 方法中進(jìn)行判斷
          // 設(shè)置配圖數(shù)據(jù)
          if (status.picture) { // 有配圖
              self.pictureHeight.constant = 100;
              self.pictureBottom.constant = 10;
              self.pictureImageView.image = [UIImage imageNamed:status.picture];
          } else { // 沒有配圖
              // 設(shè)置圖片高度為0
              self.pictureHeight.constant = 0;
              // 設(shè)置圖片底部間距為0
              self.pictureBottom.constant = 0;
      
    }
    ```
    • iOS 8之前

      1. 如果cell內(nèi)部有自動(dòng)換行的label涉波,需要設(shè)置preferredMaxLayoutWidth屬性
          - (void)awakeFromNib
      {
          // 手動(dòng)設(shè)置文字的最大寬度(目的是:讓label知道自己文字的最大寬度,進(jìn)而能夠計(jì)算出自己的frame)
          self.text_label.preferredMaxLayoutWidth = [UIScreen mainScreen].bounds.size.width - 20;
      }
      
      
      1. 設(shè)置tableView的cell估算高度
      // 告訴tableView所有cell的估算高度(設(shè)置了估算高度炭序,就可以減少tableView:heightForRowAtIndexPath:方法的調(diào)用次數(shù))
      self.tableView.estimatedRowHeight = 200;
      
      1. 在代理方法中計(jì)算cell的高度
          XMGStatusCell *cell;
          - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
          {
              // 創(chuàng)建一個(gè)cell(cell的作用:根據(jù)模型數(shù)據(jù)布局所有的子控件啤覆,進(jìn)而計(jì)算出cell的高度)
              if (!cell) {
                  cell = [tableView dequeueReusableCellWithIdentifier:ID];
              }
          
              // 設(shè)置模型數(shù)據(jù)
              cell.status = self.statuses[indexPath.row];
          
              return cell.height;
          }
          
          ```
      4. 在 cell.m中設(shè)置 height 高度
      
        - (CGFloat)height
        {
            // 強(qiáng)制布局cell內(nèi)部的所有子控件(label根據(jù)文字多少計(jì)算出自己最真實(shí)的尺寸)
            [self layoutIfNeeded];
        
            // 計(jì)算cell的高度
            if (self.status.picture) {
                return CGRectGetMaxY(self.pictureImageView.frame) + 10;
            } else {
                return CGRectGetMaxY(self.text_label.frame) + 10;
            }
        }
      
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市惭聂,隨后出現(xiàn)的幾起案子窗声,更是在濱河造成了極大的恐慌,老刑警劉巖彼妻,帶你破解...
    沈念sama閱讀 217,185評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件嫌佑,死亡現(xiàn)場(chǎng)離奇詭異豆茫,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)屋摇,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門揩魂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人炮温,你說我怎么就攤上這事火脉。” “怎么了柒啤?”我有些...
    開封第一講書人閱讀 163,524評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵倦挂,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我担巩,道長(zhǎng)方援,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,339評(píng)論 1 293
  • 正文 為了忘掉前任涛癌,我火速辦了婚禮犯戏,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘拳话。我一直安慰自己先匪,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,387評(píng)論 6 391
  • 文/花漫 我一把揭開白布弃衍。 她就那樣靜靜地躺著呀非,像睡著了一般。 火紅的嫁衣襯著肌膚如雪镜盯。 梳的紋絲不亂的頭發(fā)上岸裙,一...
    開封第一講書人閱讀 51,287評(píng)論 1 301
  • 那天,我揣著相機(jī)與錄音速缆,去河邊找鬼哥桥。 笑死,一個(gè)胖子當(dāng)著我的面吹牛激涤,可吹牛的內(nèi)容都是我干的拟糕。 我是一名探鬼主播,決...
    沈念sama閱讀 40,130評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼倦踢,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼送滞!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起辱挥,我...
    開封第一講書人閱讀 38,985評(píng)論 0 275
  • 序言:老撾萬榮一對(duì)情侶失蹤犁嗅,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后晤碘,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體褂微,經(jīng)...
    沈念sama閱讀 45,420評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡功蜓,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,617評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了宠蚂。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片式撼。...
    茶點(diǎn)故事閱讀 39,779評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖求厕,靈堂內(nèi)的尸體忽然破棺而出著隆,到底是詐尸還是另有隱情,我是刑警寧澤呀癣,帶...
    沈念sama閱讀 35,477評(píng)論 5 345
  • 正文 年R本政府宣布美浦,位于F島的核電站,受9級(jí)特大地震影響项栏,放射性物質(zhì)發(fā)生泄漏浦辨。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,088評(píng)論 3 328
  • 文/蒙蒙 一沼沈、第九天 我趴在偏房一處隱蔽的房頂上張望荤牍。 院中可真熱鬧,春花似錦庆冕、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至同辣,卻和暖如春拷姿,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背旱函。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工响巢, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人棒妨。 一個(gè)月前我還...
    沈念sama閱讀 47,876評(píng)論 2 370
  • 正文 我出身青樓踪古,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親券腔。 傳聞我的和親對(duì)象是個(gè)殘疾皇子伏穆,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,700評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 概述在iOS開發(fā)中UITableView可以說是使用最廣泛的控件,我們平時(shí)使用的軟件中到處都可以看到它的影子纷纫,類似...
    liudhkk閱讀 9,039評(píng)論 3 38
  • 我們?cè)谏弦黄锻ㄟ^代碼自定義不等高cell》中學(xué)習(xí)了tableView的相關(guān)知識(shí)枕扫,本文將在上文的基礎(chǔ)上,利用sto...
    啊世ka閱讀 1,506評(píng)論 2 7
  • UITableViewCell 父類是UIView UITableView的每一行都是一個(gè)UITableViewC...
    翻這個(gè)墻閱讀 6,596評(píng)論 0 1
  • 序引 本系列文章將介紹iOS開發(fā)中的UITableView控件辱魁,將會(huì)分成四篇文章完整的講述UITableView的...
    yetCode閱讀 2,265評(píng)論 3 40
  • UITableViewCell控件空間構(gòu)造 cell的子控件是contentView烟瞧,contentView的子控...
    CoderZXS閱讀 689評(píng)論 0 1