在开发过程中,大家经常会用到tableView,但是有的时候我们需要在TableViewCell上拖拽或者手写一个输入框,既然是列表不免就会遇到点击输入框会出现键盘将输入框挡死问题,那我们要如何解决呢?
看到网上有很多人都是通过计算键盘高速和tableView偏移量等来进行处理,方法是有效但是个人感觉太麻烦,其实苹果已经向我们提供了解决方案,而且操作十分简单。
具体方法如下:
- (void)viewDidLoad{
//监听键盘将要升起的通知
[[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(keyboardWillShow:) name:UIKeyboardWillShowNotification object:nil];
//监听键盘回收的通知
[[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(keyboardWillHide:) name:UIKeyboardWillHideNotification object:nil];
}
-(void)keyboardWillShow:(NSNotification*)note{
CGRect keyBoardRect=[note.userInfo[UIKeyboardFrameEndUserInfoKey] CGRectValue];
_tableView.contentInset = UIEdgeInsetsMake(0,0,keyBoardRect.size.height,0);
}
-(void)keyboardWillHide:(NSNotification*)note{
_tableView.contentInset = UIEdgeInsetsZero;
}
只需要加上上面几句话就可以实现想要的效果,效果图如下:
第一张,为收起键盘或者正常状态下效果图
第二张、当输入框将入编辑状态时的效果图
在上面的图中我们很容易就看到,我们编辑的输入框正好停留在键盘的上面并且不会遮挡,当然这个高度是大家自由设置的,我这里只是让他上升键盘高度。
很多人会说编辑了不会被键盘遮挡的效果图会是什么样,其实tableView是不会有任何变化的,效果如下
所以大家可以放心使用,苹果都已经为我们处理好了,我们要做的就是直接使用即可