文档章节

ios输入框被键盘挡住的解决办法

mahb520
 mahb520
发布于 2014/04/18 10:19
字数 679
阅读 111
收藏 0

做IOS开发时,难免会遇到输入框被键盘遮掩的问题。上网上搜索了很多相关的解决方案,看了很多,但是由衷的觉得太麻烦了。

    有的解决方案是将视图上的所有的东西都添加到一个滚动视图对象( UIScrollView )中,然后滚动视图实现输入框不被软键盘覆盖,个人觉得此方案好是好,但是太过麻烦。

    有的解决方案是通过一个通知 UIKeyboardDidShowNotification 去实现的,需要用到事件监听,而且需要自己定义并实现“将要开始编辑”与“结束编辑”这两个监听事件中的方法。本人也觉得很麻烦。

    参考了很多方法,都不是太理想。自己研究了一下,既然软键盘(Keyboard)出现与否是跟输入框(UITextField)紧密关联的。所以自己找到一个解决方案,没有上述两种方案那么麻烦,只需实现代理UITextFieldDelegate中的三个方法即可。

  实现方法:

   1)将输入框的代理设置为self

       (在lb文件中将输入框的delegate设置为File’s Owner 。或者使用代码textField.delegate = self;

   2)将输入框所对应的ViewController.h设置实现了UITextFieldDelegate协议

         在ViewController.m文件中实现UITextFieldDelegate的三个方法即可:

[cpp] view plaincopy

  1. //开始编辑输入框的时候,软键盘出现,执行此事件 

  2. -(void)textFieldDidBeginEditing:(UITextField *)textField 

  3.     CGRect frame = textField.frame; 

  4.     int offset = frame.origin.y + 32 - (self.view.frame.size.height - 216.0);//键盘高度216 

  5.      

  6.     NSTimeInterval animationDuration = 0.30f; 

  7.     [UIView beginAnimations:@"ResizeForKeyboard" context:nil]; 

  8.     [UIView setAnimationDuration:animationDuration]; 

  9.      

  10.     //将视图的Y坐标向上移动offset个单位,以使下面腾出地方用于软键盘的显示 

  11.     if(offset > 0) 

  12.         self.view.frame = CGRectMake(0.0f, -offset, self.view.frame.size.width, self.view.frame.size.height); 

  13.      

  14.     [UIView commitAnimations]; 

  15.  

  16. //当用户按下return键或者按回车键,keyboard消失 

  17. -(BOOL)textFieldShouldReturn:(UITextField *)textField 

  18.     [textField resignFirstResponder]; 

  19.     return YES; 

  20.  

  21. //输入框编辑完成以后,将视图恢复到原始状态 

  22. -(void)textFieldDidEndEditing:(UITextField *)textField 

  23.     self.view.frame =CGRectMake(0, 0, self.view.frame.size.width, self.view.frame.size.height); 

[cpp] view plaincopy

  1. //开始编辑输入框的时候,软键盘出现,执行此事件  

  2. -(void)textFieldDidBeginEditing:(UITextField *)textField  

  3. {  

  4.     CGRect frame = textField.frame;  

  5.     int offset = frame.origin.y + 32 - (self.view.frame.size.height - 216.0);//键盘高度216  

  6.       

  7.     NSTimeInterval animationDuration = 0.30f;  

  8.     [UIView beginAnimations:@"ResizeForKeyboard" context:nil];  

  9.     [UIView setAnimationDuration:animationDuration];  

  10.       

  11.     //将视图的Y坐标向上移动offset个单位,以使下面腾出地方用于软键盘的显示  

  12.     if(offset > 0)  

  13.         self.view.frame = CGRectMake(0.0f, -offset, self.view.frame.size.width, self.view.frame.size.height);  

  14.       

  15.     [UIView commitAnimations];  

  16. }  

  17.   

  18. //当用户按下return键或者按回车键,keyboard消失  

  19. -(BOOL)textFieldShouldReturn:(UITextField *)textField  

  20. {  

  21.     [textField resignFirstResponder];  

  22.     return YES;  

  23. }  

  24.   

  25. //输入框编辑完成以后,将视图恢复到原始状态  

  26. -(void)textFieldDidEndEditing:(UITextField *)textField  

  27. {  

  28.     self.view.frame =CGRectMake(0, 0, self.view.frame.size.width, self.view.frame.size.height);  

  29. }  


方法很简单吧?请注意一定不要忘记设置输入框的代理delegate

实现效果如下图所示:



本文转载自:http://blog.csdn.net/wmqi10/article/details/8297316

共有 人打赏支持
mahb520
粉丝 21
博文 73
码字总数 24908
作品 0
广州
项目经理
input 输入框被软键盘遮挡问题

1.安卓手机 在软键盘被弹起来的时候输入框不被遮挡,支持性良好 2.ios手机 在软键盘被弹起来的时候输入框被遮挡,体验很不好 在经过多次实验发现,ios手机输入框被弹起的瞬间是不被遮挡的,过...

爱喝水的小熊
06/06
0
0
Xamarin iOS教程之键盘的使用和设置

Xamarin iOS教程之键盘的使用和设置 Xamarin iOS使用键盘 在文本框和文本视图中可以看到,当用户在触摸这些视图后,就会弹出键盘。本节将主要讲解键盘的输入类型定义、显示键盘时改变输入视图...

大学霸
2015/06/19
0
0
周记3——解决fixed属性在ios软键盘弹出后失效的bug

  这周在做空间(“类似”qq空间)项目。首页是好友发表的说说,可以针对每条说说进行评论,评论框吸附固定在屏幕底部。此时,Bug来了...在ios上,软键盘弹出后fixed属性失效了。后来发现,...

辛月
今天
0
0
点击底部input输入框,弹出的软键盘挡住input(苹果手机使用第三方输入法 )

测试移动端页面的时候,偶然发现点击底部input输入框时,弹出的虚拟键盘偶尔会挡住input输入框。 输入框固定在页面底部,如图所示: 点击底部input输入框唤起软键盘时,软键盘挡住输入框。如...

小宇子李
08/09
0
0
fixed定位元素被安卓、ios键盘顶起的解决办法

问题背景: 当我们在写H5页面时经常会有fixed固定位置的元素存在,例如下图左中的"作业帮一课APP下载框",当我们input输入的时候键盘会弹起并将fixed定位的下载框顶起,如下图右,ios和安卓部分机...

JamesView
07/07
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

配置Spring的注解支持

声明:本栏目所使用的素材都是凯哥学堂VIP学员所写,学员有权匿名,对文章有最终解释权;凯哥学堂旨在促进VIP学员互相学习的基础上公开笔记。 配置Spring的注解支持 以上也提到了使用注解来配...

凯哥学堂
34分钟前
0
0
关于Spring Aop存在的一点问题的思考

在本人前面的文章Spring Aop原理之切点表达式解析中讲解了Spring是如何解析切点表达式的,在分析源码的时候,出现了如下将要讲述的问题,我认为是不合理的,后来本人单纯使用aspectj进行试验...

爱宝贝丶
36分钟前
0
0
JavaScript 概述

JavaScript是面向Web的编程语言。绝大多数现代网站都使用了JavaScript,并且所有的现代Web浏览器——基于桌面系统、游戏机、平板电脑和智能手机的浏览器——均包含了JavaScript解释器。这使得...

Mr_ET
今天
0
0
Java Run-Time Data Areas(Java运行时数据区/内存分配)

Java运行时数据区(内存分配) 本文转载官网 更多相关内容可查看官网 中文翻译可参考 2.5. Run-Time Data Areas The Java Virtual Machine defines various run-time data areas that are use...

lichuangnk
今天
0
0
docker learn :services docker-compose.yml

docker-compose.yml定义了服务的运行参数 version: "3" services: web: # replace username/repo:tag with your name and image details image: hub.c.163.com/dog948453219/friendlyhello d......

writeademo
今天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部