前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ios学习——键盘的收起

ios学习——键盘的收起

作者头像
mukekeheart
发布2018-03-01 10:37:34
1.8K0
发布2018-03-01 10:37:34
举报

  在开发过程中,我们经常会用到UITextField、UITextView等文本框,然后这些文本框在点击之后会自动成为第一响应者(FirstResponder),并自动弹出软键盘。然而,没有自动定义好的软键盘的回收。今天,我在开发过程中就遇到了这个问题,首先,软键盘收起会发生在两种情况下,一是当前区域为非第一响应者,二是当前区域的输入结束。具体解决方案有两种:

1、在当前页面设置点击事件,当点击事件发生时,注销当前视图的第一响应者或者设置当前摄入结束。当点击事件发生在非选中区域时,则键盘会自动回收:

代码语言:javascript
复制
1 //在viewDidLoad中 添加点击手势,为了关闭键盘的操作
2 UITapGestureRecognizer *tap1 = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(viewTapped:)];
3 tap1.cancelsTouchesInView = NO;
4 [self.view addGestureRecognizer:tap1];
代码语言:javascript
复制
//点击空白处的手势要实现的方法,设置当前输入结束
-(void)viewTapped:(UITapGestureRecognizer*)tap1
{
    [self.view endEditing:YES];  
}

 这种方法对于视图上的任何UITextField、UITextView等文本框都有效,不需要对每一个UITextField、UITextView等文本框进行进行设置。

2、利用键盘上的 回车键 来进行设置当前UITextField、UITextView等文本框不是第一响应者,这种方法对UITextField、UITextView的应用不一样,需要区别进行。

  对于UITextField,相应的UITextFieldDelegate有相关的处理

代码语言:javascript
复制
1 //设置回车键的类型和代理
2 self.themeTextField.returnKeyType = UIReturnKeyDone;
3 self.themeTextField.delegate = self ;
代码语言:javascript
复制
1 #pragma mark - textField delegate
2 - (BOOL)textFieldShouldReturn:(UITextField *)textField {
3     [textField resignFirstResponder];
4     //[self.view endEditing:YES];
5     return YES;
6 }

   对于UITextView,相应的UITextViewDelegate并没有相应的处理回车键的方法。但是,我们可以根据UITextViewDelegate提供的方法对键盘输入的值进行判断,如果为回车键(\n)则设置当前UITextView不是第一响应者,否则不操作。

代码语言:javascript
复制
1 //设置回车键的类型和代理,当前类是继承自UITextView的一个类 
2 self.delegate = self ; 
3 self.returnKeyType = UIReturnKeyDone ;
代码语言:javascript
复制
//UITextViewDelegate代理,当键盘输入变化时调用,可以通过该方法判断输入的内容
- (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range
 replacementText:(NSString *)text
{
    //判断是否是回车键
    if ([text isEqualToString:@"\n"]) {
        [textView resignFirstResponder];
        return NO;
    }
    return YES ;
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017-10-25 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档