UISearchbar 搜索按钮更换 代码实现UISearchbar去除第一响应

[self.view addSubview:[self creatTableView]];
-(UISearchBar *)searchBar
{
    mySearchBar = [[UISearchBar alloc] initWithFrame:CGRectMake(0, 0, BOUND_WIDTH, 44)];
    mySearchBar.delegate = self;
    [self searchDisplay];
    [mySearchBar setPlaceholder:@"搜索学校"];
    //遍历UISearchbar中所有试图  找到UItextField
    for(UIView *subView in [mySearchBar subviews]) {
    //As of iOS 7 beta 5,
        if([subView conformsToProtocol:@protocol(UITextInputTraits)]) {
        //改变搜索按钮名称
            [(UITextField *)subView setReturnKeyType: UIReturnKeyDone];
        } else {
            for(UIView *subSubView in [subView subviews]) {
                if([subSubView conformsToProtocol:@protocol(UITextInputTraits)]) {
                    [(UITextField *)subSubView setReturnKeyType: UIReturnKeyDone];
                }
            }      
        }
    }
     // Set the return key and keyboard appearance of the search bar
//    for (UIView *searchBarSubview in [tableSearchBar subviews]) {
//        
//        if ([searchBarSubview conformsToProtocol:@protocol(UITextInputTraits)]) {
//            
//            @try {
//                
//                [(UITextField *)searchBarSubview setReturnKeyType:UIReturnKeyDone];
//                [(UITextField *)searchBarSubview setKeyboardAppearance:UIKeyboardAppearanceAlert];
//            }
//            @catch (NSException * e) {
//                
//                // ignore exception
//            }
//        }
//    }
    return mySearchBar;
}



-(void)searchDisplay
{
    searchDisplayController = [[UISearchDisplayController alloc]initWithSearchBar:mySearchBar contentsController:self];
    searchDisplayController.active = NO;
    searchDisplayController.searchResultsDataSource = self;
    searchDisplayController.searchResultsDelegate = self;
}

-(UITableView *)creatTableView
{
    tableView = [[UITableView alloc] initWithFrame:CGRectMake(0, mySearchBar.frame.size.height, self.view.frame.size.width, self.view.frame.size.height-mySearchBar.frame.size.height) style:UITableViewStyleGrouped];
    tableView.delegate = self;
    tableView.dataSource = self;
    tableView.tableHeaderView = [self searchBar];
    [self hideExcessLine:tableView];
    return tableView;
}

//取消按钮执行方法
-(void)searchBarCancelButtonClicked:(UISearchBar *)searchBar
{
}
//搜索按钮执行方法
- (void)searchBarSearchButtonClicked:(UISearchBar *)searchBar
{
    //代码去除第一响应
    [searchDisplayController setActive:NO animated:YES];
}

//原帖地址
http://stackoverflow.com/questions/4728338/iphone-uisearchbar-done-button-always-enabled

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Swift 中,可以通过实现 UISearchBarDelegate 的 searchBarSearchButtonClicked 方法来响应搜索按钮的点击事件。如果搜索栏没有文本内容,搜索按钮默认是不可点击的。如果你想在搜索栏没有文本内容时也能点击搜索按钮,可以手动设置搜索按钮isEnabled 属性为 true。具体实现如下: ```swift class ViewController: UIViewController, UISearchBarDelegate { @IBOutlet weak var searchBar: UISearchBar! override func viewDidLoad() { super.viewDidLoad() searchBar.delegate = self } func searchBarSearchButtonClicked(_ searchBar: UISearchBar) { // 处理搜索逻辑 } func searchBar(_ searchBar: UISearchBar, textDidChange searchText: String) { if searchText.isEmpty { searchBar.showsCancelButton = false searchBar.searchTextField.rightView?.isHidden = false searchBar.searchTextField.rightViewMode = .always searchBar.searchTextField.clearButtonMode = .whileEditing searchBar.searchTextField.enablesReturnKeyAutomatically = false searchBar.searchTextField.returnKeyType = .default searchBar.searchTextField.reloadInputViews() searchBar.setShowsCancelButton(false, animated: true) searchBar.searchTextField.resignFirstResponder() searchBar.searchTextField.endEditing(true) searchBar.searchTextField.isUserInteractionEnabled = true searchBar.searchTextField.isEnabled = true searchBar.searchTextField.reloadInputViews() searchBar.searchTextField.returnKeyType = .search searchBar.searchTextField.becomeFirstResponder() } else { searchBar.searchTextField.rightView?.isHidden = true searchBar.searchTextField.rightViewMode = .always searchBar.searchTextField.clearButtonMode = .whileEditing searchBar.searchTextField.enablesReturnKeyAutomatically = true searchBar.searchTextField.returnKeyType = .search searchBar.searchTextField.reloadInputViews() searchBar.setShowsCancelButton(true, animated: true) searchBar.searchTextField.becomeFirstResponder() } } } ``` 在实现中,我们在 searchBar(_:textDidChange:) 方法中判断搜索栏的文本内容是否为空,如果为空,手动设置搜索按钮isEnabled 属性为 true,这样就能在没有文本内容时点击搜索按钮了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值