系统导航条应该再iOS开发项目中都会有用到。但是有时间长篇大论的在C里边写一大串代码,未必会有些繁杂。基于封装角度,今天我们来做一个导航条UIBarButtonItem的进一步封装,让代码更简洁
今天通过给导航条添加图片来举例说明
我们先看下系统给我们开出来的方法
219267E1-A2E9-4DD5-8278-DB610C94BE14.png
这里封装采用自定义view,通过分类方式实现。目的为了调用方便。当然这是项目源码,可放心使用。直接上代码
53975298-EE7A-44B8-AEEF-D9CBB0C15EA3.png
/**
系统导航条按钮UIBarButtonItem封装
@param imageName 图片名字
@param target 当前Controller
@param action 方法名
@return 返回根据图片可定制UIBarButtonItem
*/
+(instancetype)itemWithImageNamed:(NSString *)imageName
target:(id)target
action:(SEL)action;
这是分类.h里边的方法。上边是调用示例,下边为开出来的方法。注释比较详细。代码可创建分类后直接拷贝过去使用
.m实现方法
4ED6A184-7141-46D5-AD28-1FDCC87B7279.png
/**
系统导航条按钮UIBarButtonItem封装
@param imageName 图片名字
@param target 当前Controller
@param action 方法名
@return 返回根据图片可定制UIBarButtonItem
*/
+(instancetype)itemWithImageNamed:(NSString *)imageName
target:(id)target
action:(SEL)action{
UIButton * Barbutton = [[UIButton alloc]init];
[Barbutton setImage:[UIImage imageNamed:imageName] forState:UIControlStateNormal];
[Barbutton addTarget:target action:action forControlEvents:UIControlEventTouchUpInside];
[Barbutton sizeToFit];
return [[UIBarButtonItem alloc]initWithCustomView:Barbutton];
}
调用示例。在Controller里边直接调用即可
/**
系统导航条按钮封装,
可直接倒入头文件使用
调用示例
右侧导航条按钮,
self.navigationItem.rightBarButtonItem = [UIBarButtonItem itemWithImageNamed:@"message_pic"
target:self
action:@selector(didSelectRightNavButton)];
左侧导航条按钮
self.navigationItem.leftBarButtonItem = [UIBarButtonItem itemWithImageNamed:@"message_pic"
target:self
action:@selector(didSelectRightNavButton)];
*/
很实用的小技巧。每天进步一点点