自定义UI的基本结构
- .h文件
@protocol TRIPHotelXXXViewDelegate <NSObject> - ( void )actionA; @end @interface TRIPHotelXXXView : UIView @property (nonatomic,weak) id <TRIPHotelXXXViewDelegate> delegate; + (instancetype)xxxView:(NSDictionary *)info (CGFloat)width; @end |
- .m文件
@implementation TRIPHotelXXXView{ // 类变量 } - ( void )dealloc{ // 内存释放 SafeSuperDealloc( super ); } - (id)initWithFrame:(CGRect)frame{ self = [ super initWithFrame:frame]; if (self) { // 变量初始化 } return self; } - ( void )layoutSubviews{ [ super layoutSubviews]; CGFloat y = 0.0 ; // 子View的布局,y动态调整 // 更新自定义UI的高度 CGRect rect = self.frame; rect.size.height = y; self.frame = rect; } + (instancetype)xxxView:(NSDictionary *)info (CGFloat)width;{ // 用view的数据及父view的宽度定义并初始化一个UI TRIPHotelXXXView *view = [[TRIPHotelXXXView alloc] initWithFrame:CGRectMake( 0 , 0 , width, 0 )]; [view updateViewWithInfo:info]; return view; } - ( void )updateViewWithInfo:(NSDictionary *)info{ // view本身的数据填充 // 重新布局子View [self layoutSubviews]; } #pragma mark - Action - ( void )onSomeActionHappened:(id)sender{ if (_delegate && [_delegate respondsToSelector: @selector (actionA)]) { [_delegate actionA]; } } |
结构分析
- 数据准备好之前view已从原父view移除,并置为nil,之后进行UI的定义、初始化、添加到父view
- 必要之时,可将updateViewWithInfo:方法作为外部接口,在数据更新后也更新view的布局
- 自定义view由众多子view组成,高度动态调整,但也可以在初始化的时候置为定值,然后在固定高度的view中布局子view
- 可扩展性较强,可随时更具需求调整子view及布局
- 向外部提供delegate接口,根据业务在外部执行相应的动作
- 结构清晰