IOS中隐藏UITextField自动弹出的软键盘的若干方法

OS上的软键盘对于使用者是一个很好用的功能,其包含了各种预定义格式的键盘;但对于开发者绝对是一个蛋疼的东西!下面记录一下我在开发过程中遇到的一些关于软键盘事项,希望能对读到这篇博文的人有所帮助。

首先,软键盘总体上分为两种:iPhone的和iPad的,为何这样分类,因为iPad的软键盘会比起iPhone的多出一个右下角的隐藏键盘的按键。
其次,能弹出软键盘的控件主要有两种:UITextField和UITextView,UITextView能接受回车换行符;而UITextField只能是单行的,这样将对收起软键盘起到帮助。

现在说说UITextField下收起软键盘的方法:(由于UITextField不能换行,所以换行回车键被赋予了另外的含义)
注:iOS4下iPad的软键盘的右下角隐藏键盘按键有时候会失效,但是在原生应用内是有效的,暂时未找到原因。
第一种:这是网上流传最广的一个方法,首先实现UITextFieldDelegate,然后实现textFieldShouldReturn:方法在按下换行键时除去对应UITextField的firstResponder即可实现隐藏。



  • - (BOOL)textFieldShouldReturn:(UITextField *)textField  
  • {  
  •   [textField resignFirstResponder];  
  •   return NO;  
  • }  


第二种:在开发过程中,无意发现,给UITextField的Did End on Exit事件连接一个selector即可实现在回车时隐藏键盘的功能(即使这个方法内不作任何处理)
具体步骤:
1. 打开Nib文件,并按command+option+enter打开辅助编辑器,选定需要连接事件的文件
2. 右键点击Nib编辑器中对应的TextField
3. 选择Did End on Exit事件并且将其拖动至右边的辅助编辑器中
4. 按照提示新建一个事件处理方法,编辑器会自动创建连接
至此,即可在点击换行的时候自动关闭软键盘了。但要注意的是,使用这个方法不能连接delegate,一旦连接delegate,消息就会被delegate处理,原来的事件也就不会被触发了。

为什么会这样?上面也说过,UITextField是不接受回车的,所以回车被用作另外的用途,但为什么不连接Did End on Exit就不可以呢?这个可能是iOS的内部逻辑在对按下回车这个事件使用了错误的判断导致的,具体可能要查阅官方文档才清楚了。



另外一部分方法来自转载http://mobile.51cto.com/iphone-387450.htm



二、点击Return自动转到下个文本框

当页面中有很多个文本框时,如果每次都需要点文本框激活软键盘、输入后点击Return隐藏软键盘、再点击下一个文本框……这样操作起来太繁琐了。 于是我们希望能够实现点击Return时能够自动转到下一个文本框。尤其是对于最后一个文本框,希望能够在点击Return时执行下一步操作。

例如对于登录页面。它上面有 账号文本框(nameTextField)、密码文本框(passTextField)、登录按钮(loginButton)。
我们希望——点击账号文本框软键盘的Return时跳转到密码文本框,点击密码文本框软键盘的Return时执行登录。
因为这两个文本框的功能不同,不能像上一节那样写一个TextField_DidEndOnExit做统一处理,而应该分别建立各自的事件处理方法。

回到storyboard,右击账号文本框(nameTextField)弹出面板,按住Did End on Exit事件旁边的圆圈,然后拖曳到右侧.h文件的空白地方,此时会弹出一个对话框给方法命名。输入名称 (nameTextField_DidEndOnExit)后回车确定,便自动生成了该事件方法。
随后按照同样的做法,为密码文本框(passTextField)的Did End on Exit事件连接方法(passTextField_DidEndOnExit)。
来到.m文件,填写具体代码——

 
 
  1. - (IBAction)nameTextField_DidEndOnExit:(id)sender { 
  2.     // 将焦点移至下一个文本框. 
  3.     [self.passTextField becomeFirstResponder]; 
  4. - (IBAction)passTextField_DidEndOnExit:(id)sender { 
  5.     // 隐藏键盘. 
  6.     [sender resignFirstResponder]; 
  7.     // 触发登陆按钮的点击事件. 
  8.     [self.loginButton sendActionsForControlEvents:UIControlEventTouchUpInside]; 

对于账号文本框转密码文本框,不需要隐藏软键盘,只需要调用becomeFirstResponder激活新的文本框就行了。
对于密码文本框Return后执行登录。因为不再需要显示软键盘,所以还是得调用resignFirstResponder隐藏软键盘,然后触发登录按钮(loginButton)的UIControlEventTouchUpInside事件进行登录。

运行一下,可发现已经达到我们希望的效果了。点击账号文本框软键盘的Return时跳转到密码文本框,点击密码文本框软键盘的Return时执行登录。
怎么都是“Return”,转换文本框与执行登录明明是不同的功能?
于是将账号文本框的Return Key属性设为“Next”,将密码文本框的Return Key属性设为“Done”,使界面与功能一致。

三、轻触背景隐藏软键盘

只能通过Return关闭软键盘太不灵活了,应该提供轻触背景隐藏软键盘的功能。

在storyboard,点击背景View,将它的Custom Class设置为UIControl,这样才会出现Touch Down事件。
右击背景View弹出面板,按住Touch Down事件旁边的圆圈,然后拖曳到右侧.h文件的空白地方建立该事件的处理方法。
来到.m文件,填写具体代码——

 
 
  1. - (IBAction)View_TouchDown:(id)sender { 
  2.     // 发送resignFirstResponder. 
  3.     [[UIApplication sharedApplication] sendAction:@selector(resignFirstResponder) to:nil from:nil forEvent:nil]; 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值