自定義UITableViewCell

来源:http://www.cnblogs.com/xueyao/archive/2016/02/11/5186236.html
-Advertisement-
Play Games

隨著日常的使用,系統提供的cell已經不能滿足開發的需要,因為系統提供的是單一的,所以 這就引來了自定義cell的出現,可以根據 自己的需要來佈局各個控制項所處的位置。不同位置顯示不同的控制項。 創建一個類,繼承於UITableCell. 自定義cell,簡單的來說可以分為三步 1.將所有cell要顯示


隨著日常的使用,系統提供的cell已經不能滿足開發的需要,因為系統提供的是單一的,所以 這就引來了自定義cell的出現,可以根據 自己的需要來佈局各個控制項所處的位置。不同位置顯示不同的控制項。

創建一個類,繼承於UITableCell.

自定義cell,簡單的來說可以分為三步

1.將所有cell要顯示的子視圖控制項聲明成屬性

@interface MyTableViewCell : UITableViewCell

@property (nonatomic, retain)UIImageView *headerImageView;  //頭像
@property (nonatomic, retain)UILabel *nameLabel;   // 姓名
@property (nonatomic, retain)UILabel *genderLabel;  // 性別
@property (nonatomic, retain)UILabel *ageLabel;   //年齡

2.重寫cell的初始化方法,frame給定為0,將控制項添加到cell上面進行顯示,一定要註意使用self.contentView添加

//CGRectZero表示0

//重寫cell的初始化方法
- (instancetype)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier{
    self = [super initWithStyle:style reuseIdentifier:reuseIdentifier];
    if (self) {
        [self setupSubviews];
    }
    return self;
}
- (void)setupSubviews{
    _headerImageView = [[UIImageView alloc] initWithFrame:CGRectZero];
    _headerImageView.backgroundColor = [UIColor greenColor];
    //自定義cell內部添加子視圖時,不能使用self,應該是使用self.contentView
    [self.contentView addSubview:_headerImageView];
    
    _nameLabel = [[UILabel alloc] initWithFrame:CGRectZero];
    _nameLabel.backgroundColor = [UIColor grayColor];
    [self.contentView addSubview:_nameLabel];
    
    _genderLabel = [[UILabel alloc] initWithFrame:CGRectZero];
    _genderLabel.backgroundColor = [UIColor cyanColor];
    [self.contentView addSubview:_genderLabel];
    
    _ageLabel = [[UILabel alloc] initWithFrame:CGRectZero];
    _ageLabel.backgroundColor = [UIColor yellowColor];
    [self.contentView addSubview:_ageLabel];
}

3.重寫layouSubviews方法,給定內部控制項的具體位置

//指定內部控制項的大小
- (void)layoutSubviews{
    [super layoutSubviews];
    _headerImageView.frame = CGRectMake(5, 5, 50, 80);
    _nameLabel.frame = CGRectMake(65, 5, 150, 20);
    _genderLabel.frame = CGRectMake(65, 35, 150, 20);
    _ageLabel.frame = CGRectMake(65, 65, 150, 20);
}

但如果想方便以後操作的話,可以在自定義cell的時候,使用到數據模型,方便賦值,取值。

1.導入模型,將模型與cell進行綁定,聲明模型屬性

//在cell內部綁定一個模型屬性
@property (nonatomic, retain)Student *stu;

2.重寫模型屬性的setter方法,內部使用模型為內部控制項賦值。

//重寫模型的setter方法,完成賦值
- (void)setStu:(Student *)stu{
    if (_stu != stu) {
        _stu = [stu retain];
        //為內部控制項進行賦值
        _headerImageView.image = [UIImage imageNamed:_stu.picture];
        _nameLabel.text = _stu.name;
        _genderLabel.text = _stu.gender;
        _ageLabel.text = _stu.age;
    }
}

如果是在MRC環境下使用的話,一定要註意記憶體管理哦。

自定義cell的使用方法與系統提供的cell使用方法,沒有區別。

//cell顯示的內容,數據
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
    static NSString *reuseIdentifier = @"reuse";
    MyTableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:reuseIdentifier];
    if (cell == nil) {
        cell = [[[MyTableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:reuseIdentifier]autorelease];
        //cell.selectionStyle = UITableViewCellSelectionStyleNone;
    }
//使用模型屬性來賦值
    Student *student = _dataArray[indexPath.row];
    cell.stu = student;
//    cell.nameLabel.text = student.name;
//    cell.ageLabel.text = student.age;
//    cell.genderLabel.text = student.gender;    
    return cell;
}

 自定義cell,一個重點就是內部各控制項該怎麼樣佈局,控制項顯示的屬性有哪些、而怎麼樣局面,擺放的位置還是要自己設計清楚的。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 有前輩說過,在JavaScript中,一切皆對象。由此可見,作為JavaScript的核心之一,對象是有多麼重要。雖然今天走親戚有點累,但還是得寫寫這個對象,免得吃幾天好的,就又忘光了。 1.創建對象 通過內置對象創建: var obj1 = new Object(); typeof obj1; /
  • 表單標簽在網站中主要負責的是進行與用戶間的交互, 如果沒有了交互, 那麼網站就只是一個展示, 會死氣沉沉的. <form>表單標簽 <form>表單標簽可以把瀏覽者(也就是我們用戶自己)輸入的數據傳送到伺服器端, 這樣伺服器程式就可以處理表單傳過來的數據, 完成與用戶的交互, 在任何的開發中, 交互
  • javascript面向對象的程式設計-創建對象;理解對象、屬性、方法、引用類型、基本類型、原型模式;創建對象的幾種方法。
  • 強制轉換為布爾類型: 1 <script> 2 var text =Boolean(0) //=>以下轉換的類型都為false 3 text = Boolean(0.0) 4 text = Boolean(-0) 5 text = Boolean(0/0) 6 text = Boolean(NaN)
  • 今天思考下前端源碼安全的東西(不是前端安全,只是針對於源碼部分)。在我看來,源碼安全有兩點,一是防止抄襲,二是防止被攻破。實際上講,前端的代碼大多是沒有什麼可抄襲性,安全更是形同虛設的(任何前端輸入都是不能相信的)。但如果還是想防止源碼被查看,HTML、CSS並不能做什麼,最終都會用露出來(最簡單用
  • 第三篇博客, 這次說的是插入鏈接類標簽, 我們平常在網頁中經常能看到藍色的鏈接類標簽, 或者是一張圖片, 一個電郵, 這些都是插入鏈接類的標簽起的作用. <a></a>鏈接標簽 <a>鏈接標簽可實現超鏈接, 它在網頁中是無處不在的, 只要有鏈接的地方, 就會有這個標簽, 它的語法和其他的標簽不太相同
  • 上一篇文章提到了javascript中可變值與不可變值,如果你不知道什麼是可變值和不可變值,可以先去看看那篇文章,再回來看這篇,因為這篇文章是基於可變值與不可變值講解的。 那我就預設你知道什麼是可變值與不可變值。 1.對於不可變值來說(也就是數字,字元串,布爾,null,undefined),它們是
  • 字元串原始值修改不了1 var str = "abc"; 2 str[0] = "d"; 3 console.log(str[1]="f"); >>f 4 console.log(str[0]); >>a 5 console.log(str); >>abc提試:字元串是可以通過[]的形式訪問的。 /
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...