Xib及自定义控件封装
view的封装(自定义控件封装)
- 如果一个view内部的子控件比较多,一般会考虑自定义一个view,把它内部子控件的创建屏蔽起来,不让外界关心
- 外界可以传入对应的模型数据给view,view拿到模型数据后给内部的子控件设置对应的数据
- 封装控件的基本步骤
- 在initWithFrame:方法中添加子控件,提供便利构造方法
- 在layoutSubviews方法中设置子控件的frame(一定要调用super的layoutSubviews)
- 增加模型属性,在模型属性set方法中设置数据到子控件上
Xib和storyboard对比
- 共同点:
- 都用来描述软件界面
- 都用Interface Builder工具来编辑
- 本质都是转换成代码去创建控件
- 不同点
- 新建自定义控件类(如KZKShopView) Subclass of选择 UIView
- 新建Xib文件(文件名建议和View的类名一直,这样看起来比较直观)
- 修改Xib中View的类名(Custom Class)
- 封装xib的加载过程
@interface KZKShopViwe : View
+ (instancetype)shopView;
@end
@implementation KZKShopwView
+ (instancetype)shopView{
return [[[NSBundle mainBundle] loadNidNamed:@"KZKShopView" owver:nil options:nil] lastobject];
}
@end
- 增加模型属性,在模型属性set方法中设置数据到子控件上
注意点
- 一个控件有两种创建方式
- 通过代码创建
- 初始化时一定会调用initWithFrame:方法
- 通过xib\storyboard创建
- 初始化时不会调用initWithFrame:方法,只会调用initWithCoder:方法
- 初始化完毕后会调用awakeFromNib方法
- 有时候希望在控件初始化时做一些初始化操作,比如添加子控件、设置基本属性
- 这时需要根据控件的创建方式,来选择在initWithFrame:、initWithCoder:、awakeFromNib的哪个方法中操作
三者的特点
- UIButton
- 既能显示文字,又能显示图片(能显示2张图片,背景图片、内容图片)
- 长按高亮的时候可以切换图片\文字
- 直接通过addTarget...方法监听点击
- UIImageView
- 能显示图片,不能直接通过addTarget...方法监听点击
- UILabel
- 能显示文字,不能直接通过addTarget...方法监听点击
如何选择
- 仅仅是显示数据,不需要点击
- 不仅显示数据,还需要监听点击
- 建议选择UIButton
- 其实UIImageView、UILabel也可以通过手势识别器来监听,这里暂时没有学习
- 长按控件后,会改变显示的内容
- 不用考虑了,选择UIButton(因为UIButton有highlighted这种状态)
- 同时显示2张图片:背景图片、内容图片