UISearchBar自定义取消按钮

前些天工作需要做一个搜索框,需要自定义右侧的取消按钮的颜色和文字,于是上网搜了一些资料,发现都出自一个模板,有一点偏差,所以在这里更正一下,让同学们少走一点弯路。

首先初始化一个UISearchBar

- (void)initSearchBar
{
    _searchBar = [[UISearchBar alloc] initWithFrame:CGRectMake(20, 100, 300, 44)];
    _searchBar.translucent  = YES;
    _searchBar.delegate     = self;
    _searchBar.placeholder  = @"名称";
    _searchBar.keyboardType = UIKeyboardTypeDefault;
    [_searchBar setShowsCancelButton:YES];//显示右侧取消按钮
    [self.view addSubview:self.searchBar];
}

我想要将右侧的取消按钮文字改成“搜索”,很显然它是一个UIButton,但是我们不能拿到这个属性,也没有更改它的方法。我不得不遍历UISearchBar的子控件找到她,这里介绍一个私有方法打印它的所有子控件(提交AppStore时不要出现这个方法)。

 NSLog(@"%@", [_searchBar performSelector:@selector(recursiveDescription)]);

打印结果如下:
<UISearchBar: 0x7fcff0e5a260; frame = (20 100; 300 44); text = ''; opaque = NO; gestureRecognizers = <NSArray: 0x7fcff0f4e290>; layer = <CALayer: 0x7fcff0e1acb0>>
| <UIView: 0x7fcff0f4bf60; frame = (0 0; 300 44); clipsToBounds = YES; autoresize = W+H; layer = <CALayer: 0x7fcff0f4d150>>
|    | <UISearchBarBackground: 0x7fcff0f4ea50; frame = (0 0; 300 44); opaque = NO; userInteractionEnabled = NO; layer = <CALayer: 0x7fcff0f4ee10>>
|    | <UISearchBarTextField: 0x7fcff0f502d0; frame = (0 0; 0 0); text = ''; clipsToBounds = YES; opaque = NO; layer = <CALayer: 0x7fcff0f50820>>
|    |    | <_UISearchBarSearchFieldBackgroundView: 0x7fcff0d3d100; frame = (0 0; 0 0); opaque = NO; autoresize = W+H; userInteractionEnabled = NO; layer = <CALayer: 0x7fcff0d22a40>>
|    | <UINavigationButton: 0x7fcff0c4a170; frame = (0 0; 54 30); opaque = NO; layer = <CALayer: 0x7fcff0c07ea0>>

这时我发现在二级子控件中有个有一个UINavigationButton,就是要更改的取消按钮(其它版本的答案都写的它在UISearchBar的一级子控件中)。我们虽然不能调用UINavigationButton这个类,但是我们清楚它继承了UIButton,所以我们可以取到并更改它。

for (UIView *view in [[_searchBar.subviews lastObject] subviews]) {
    if ([view isKindOfClass:[UIButton class]]) {
        UIButton *cancelBtn = (UIButton *)view;
        [cancelBtn setTitle:@"搜索" forState:UIControlStateNormal];
    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值