需求场景
1. 控制器获取数据后更新自定义控件上的各个子控件的数值显示(例如UILabel.text, UIImageView.image等)
2. setter方法说明:在属性被赋值的时候,会调用该属性对应的setter方法,以此实现控件动态赋值
存在问题
在学习自定义控件的过程中,刚开始的时候碰到问题是如何给各控件动态赋值,最初的想法是把各控件属性放在.h文件中定义.然后在控制器内获取数据一一赋值(可行),但是这样就增加了控制器中的代码,比如给定一个场景:
collectionViewCell中,有10个控件,需要显示10个数据,这样的话就要在代理cellForRowAtIndexPath中进行十次赋值。在学会使用在setter方法中进行赋值后,赋值的操作可以在自定义控件内进行赋值,cellForRowAtIndexPath中的代码量就减少了很多,并且这种监听值改变后进行操作的方式在其他地方都很好使用。
使用流程
1. 创建自定义控件View,在.m文件中声明和创建子控件;
2. 创建对应的数据模型Model;
3. 在View.h中导入Model.h文件,声明model:@property ... Model *model;
4. 在view.m中重写model的setter方法:- (void)setModel:(Model *)model {}, 并在该方法内把model的值赋值给对应的控件;
5. 在控制器中请求到数据并储存到Model中;
6. 将Model赋值给View.model(这个时候就会调用步骤4中的代码,实现赋值).
如果是tableView等控件,在请求成功后调用 reloaData 刷新数据,就会重新调用cellForRowAtIndexPath,将有值的model赋值给cell,如果就是普通的UIView,在请求成功的回调里进行model赋值即可。
代码示例
cell.h-------------
@class CheckCollectionViewCellModel;
@interface CheckCollectionViewCell : UICollectionViewCell
//在view.h 中声明了 model
@property (nonatomic, strong) CheckCollectionViewCellModel *checkModel;
@end
cell.m------------- 关键赋值
// 在view.m 中重写了 model 的 setter 方法,给各控件赋值
- (void)setCheckModel:(CheckCollectionViewCellModel *)checkModel {
_checkModel = checkModel;
self.checkType.text = checkModel.checkType;
self.waitingNumberLabel.centerLabel.text = checkModel.waitingLineNumber;
self.numberWithTimeLabel.topDataLabel.text = [NSString stringWithFormat:@"共有%@位", checkModel.sumCheckerNumber];
self.numberWithTimeLabel.buttomDataLabel.text = [NSString stringWithFormat:@"大约%@分钟", checkModel.waitTime];
self.numberWithCurrentLabel.topDataLabel.text = checkModel.lineNumber;
self.numberWithCurrentLabel.buttomDataLabel.text = checkModel.currentNumber;
}
控制器-------------
- (__kindof UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath {
CheckCollectionViewCell *cell = [collectionView dequeueReusableCellWithReuseIdentifier:@"cell" forIndexPath:indexPath];
//self.dataSource数组储存了checkModel
cell.checkModel = [self.dataSource objectAtIndex:indexPath.item];
return cell;
}
网友评论