IOS-UITableView-Cell的重繪-避免出現重疊視圖

在IOS6.0以後,UITableView新增了兩個方法

用於Xib的
- (void)registerNib:(UINib *)nib forCellReuseIdentifier:(NSString *)identifier NS_AVAILABLE_IOS(5_0); 

用於手寫的
- (void)registerClass:(Class)cellClass forCellReuseIdentifier:(NSString *)identifier NS_AVAILABLE_IOS(6_0);

很多書上的方法,關於UITableView的重繪方法,都是這麼寫的

UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"Cell"];
if (cell == nil) {
        cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault
                                      reuseIdentifier:CellIdentifier];
        //設置你的cell
}
這樣寫用在自定義的Cell上就會出現重複的問題

避免這個方法的解決方案就是在創建UITableView的時候,直接register一個Cell

[self.tableView registerClass:[CustomCell class] forCellReuseIdentifier:@"CustomCell"];
用純代碼的就使用registerClass,用Xib的就是用registerNib
然後在(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath這個方法裏

直接使用

    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"Cell" forIndexPath:indexPath];
關於自定義Cell,我們可以先初始化UI,然後設置一個Model,在Model再進行數據的處理,以下是我的自定義Cell的寫法

-(instancetype)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier
{
    if (self == [super initWithStyle:style reuseIdentifier:reuseIdentifier]) {
        [self setupView];//先創建UI
    }
    return self;
}
- (void)setModel:(getChatModel *)model  //處理數據
{
    [self.headImageView setImageWithURL:[NSURL URLWithString:[NSString stringWithFormat:IMG_BASE_HOST,    model.fdUserHeaderUrl]] placeholderImage:[UIImage imageNamed:@"img_user_header_cache.jpg"] usingAc    tivityIndicatorStyle:UIActivityIndicatorViewStyleGray];
    [self.headImageView addGestureRecognizer:[[UITapGestureRecognizer alloc] initWithTarget:self actio    n:@selector(act_headimg)]];
}





發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章