以下为大家带来我整理总结的几种隐藏键盘的方法。

一、隐藏自身软键盘

当对于有多个UITextField控件都想通过点击“Return”来隐藏自身软键盘的情况,这时的最好办法是使用Did End on Exit事件。在点击软键盘右下角的“Return”button后,会触发该事件。

该事件有一个sender參数表示当前文本框,这样便能够编写一个通用的事件处理方法(.m文件)

  1. - (IBAction)TextField_DidEndOnExit:(id)sender {
  2. // 隐藏键盘.
  3. [sender resignFirstResponder];
  4. }

然后在.h文件里填写该方法的声明——

  1. - (IBAction)TextField_DidEndOnExit:(id)sender;

回到storyboard,并按command+option+enter打开辅助窗体,使辅助窗体显示.h文件。

选中一个UITextField控件,点击鼠标右键弹出面板,鼠标左键按住Did End on Exit事件旁边的圆圈,然后拖曳到右側.h文件的TextField_DidEndOnExit方法上,便会建立好事件连接。

随后依照相同的做法。将其它UITextField控件的Did End on Exit事件也连接到TextField_DidEndOnExit方法。

执行一下,可发现每一个文本框的软键盘都能够通过点击“Return”来隐藏了。

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

当页面中有非常多个文本框时,假设每次都须要点文本框激活软键盘、输入后点击Return隐藏软键盘、再点击下一个文本框……这样操作起来太繁琐了。 于是我们希望可以实现点击Return时可以自己主动转到下一个文本框。

尤其是对于最后一个文本框。希望可以在点击Return时运行下一步操作。

比如对于登录页面。

它上面有 账号文本框(nameTextField)、password文本框(passTextField)、登录button(loginButton)。

我们希望——点击账号文本框软键盘的Return时跳转到password文本框。点击password文本框软键盘的Return时运行登录。

由于这两个文本框的功能不同,不能像上一节那样写一个TextField_DidEndOnExit做统一处理,而应该分别建立各自的事件处理方法。

回到storyboard,右击账号文本框(nameTextField)弹出面板。按住Did End on Exit事件旁边的圆圈。然后拖曳到右側.h文件的空白地方,此时会弹出一个对话框给方法命名。

输入名称 (nameTextField_DidEndOnExit)后回车确定,便自己主动生成了该事件方法。

随后依照相同的做法。为password文本框(passTextField)的Did End on Exit事件连接方法(passTextField_DidEndOnExit)。

来到.m文件。填写详细代码——

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

对于账号文本框转password文本框,不须要隐藏软键盘。仅仅须要调用becomeFirstResponder激活新的文本框即可了。

对于password文本框Return后运行登录。由于不再须要显示软键盘。所以还是得调用resignFirstResponder隐藏软键盘,然后触发登录button(loginButton)的UIControlEventTouchUpInside事件进行登录。

执行一下,可发现已经达到我们希望的效果了。点击账号文本框软键盘的Return时跳转到password文本框。点击password文本框软键盘的Return时执行登录。

怎么都是“Return”,转换文本框与运行登录明明是不同的功能?

于是将账号文本框的Return Key属性设为“Next”。将password文本框的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];
  4. }

把这些方法分享给大家希望能对读者朋友们有所帮助。

iOS开发隐藏键盘方法总结的更多相关文章

  1. iOS开发- 隐藏键盘总结

    一.隐藏自身软键盘 当对于有多个UITextField控件都想通过点击"Return"来隐藏自身软键盘的情况.这时的最好办法是使用Did End on Exit事件.在点击软键盘右 ...

  2. iOS-提高iOS开发效率的方法和工具

    提高iOS开发效率的方法和工具 介绍 这篇文章主要是介绍一下我在iOS开发中使用到的一些可以提升开发效率的方法和工具. IDE 首先要说的肯定是IDE了,说到IDE,Xcode不能跑,当然你也可能同时 ...

  3. iOS开发——实用篇&提高iOS开发效率的方法和工具

    提高iOS开发效率的方法和工具 介绍 这篇文章主要是介绍一下我在iOS开发中使用到的一些可以提升开发效率的方法和工具. IDE 首先要说的肯定是IDE了,说到IDE,Xcode不能跑,当然你也可能同时 ...

  4. iOS 点击屏幕空白区隐藏键盘方法

    iOS开发中,经常要用到输入框,可默认情况下,输入框出来之后,除非点击键盘上面的“Done”或“Next”按钮才能将其隐藏.站在用户体验的角度上看,这种情况很不友好,尤其是不能突显苹果操作的便捷性. ...

  5. IOS学习:隐藏键盘方法

    1.点击界面的其它空白地方隐藏      由于UIViewController是继承自UIResponder的,所以可以覆写- (void)touchesBegan:(NSSet *)touches ...

  6. iOS开发--隐藏(去除)导航栏底部横线

    iOS开发大部分情况下会使用到导航栏,由于我司的app导航栏需要与下面紧挨着的窗口颜色一致,导航栏底部的横线就会影响这个美观,LZ使用了以下方法.觉得不错,分享来给小伙伴们. 1)声明UIImageV ...

  7. <转>提高iOS开发效率的方法和工具

    介绍 这篇文章主要是介绍一下我在iOS开发中使用到的一些可以提升开发效率的方法和工具. IDE 首先要说的肯定是IDE了,说到IDE,Xcode不能跑,当然你也可能同时在使用AppCode等其他的ID ...

  8. 提高iOS开发效率的方法和工具

    http://www.cocoachina.com/ios/20150717/12626.html 介绍 这篇文章主要是介绍一下我在iOS开发中使用到的一些可以提升开发效率的方法和工具. IDE 首先 ...

  9. iOS开发之 - 键盘处理神器 IQKeyboardManager

    平常在开发中,用到输入框的地方不胜其数,当输入框位于屏幕底部时,弹起的键盘很可能覆盖输入框,导致用户看不到输入结果,体验较差...... IQKeyboardManager 可以很简单快捷的解决键盘遮 ...

随机推荐

  1. 转---派遣例程与IRP结构

    派遣例程与IRP结构   文章出处:http://www.cnblogs.com/zmlctt/p/3978124.html#commentform   提到派遣例程,必须理解IRP(I/O Requ ...

  2. (2)html 块类

    span span是内联元素,内联元素的特点:在显示时通常不会以新行开始 div div是块级元素,块级元素会换新行 class 设置 <head> <style> .citi ...

  3. "从客户端中检测到有潜在危险的 Request.Form 值"的解决方案汇总

    #事故现场 在一个asp.net 的项目中,前端通过ajax将富文本中的文字内容post到服务端的一个ashx中,在ashx中尝试读取参数值时, 结果报错:“从客户端中检测到有潜在危险的 Reques ...

  4. 网站robots.txt探测工具Parsero

    网站robots.txt探测工具Parsero   robots.txt文件是网站根目录下的一个文本文件.robots.txt是搜索引擎中访问网站的时候要查看的第一个文件.当搜索引擎访问一个站点时,它 ...

  5. vim可视化&Linux系统安全最小化原则& su & sudo

    一.vim在可视化模式下编辑 crl+v,会变成-- VISUAL BLOCK --,然后用上下左右键去选中. 多行注释: ESC进入命令行模式; Ctrl+v进入VISUAL BLOCK模式 上下左 ...

  6. 【swagger】2.swagger提供开发者文档--返回统一格式篇【spring mvc】【spring boot】

    接着上一篇来说, 不管正常返回结果还是后台出现异常,应该返回给前台统一的响应格式. 所以这一篇就为了应对解决这个问题. ======================================== ...

  7. win7 32位安装pyqt

    参考 http://blog.csdn.net/fairyeye/article/details/6607981 http://www.cnblogs.com/toSeek/p/6363036.htm ...

  8. Highcharts常用的最核心的参数选项配置详细说明

    Highcharts提供大量的选项配置参数,您可以轻松定制符合用户要求的图表,目前官网只提供英文版的开发配置说明文档,而中文版的文档网上甚少,且零散不全.这里,我把Highcharts常用的最核心的参 ...

  9. react webapp 开发小结

    1.监听props的方法 componentWillReceiveProps(nextProps) { // } 2.监听state的方法 3.props 传递的方法 <AlarmList {. ...

  10. WMS8_条码界面操作简要说明(包装作业)

    说明:条码界面的主要用途是包装作业 这个客户端,完全是JS实现的     可以从 All operation看板视图 Picking的表单视图                 All operatio ...