注意:

关于iOS 4.3的解决方案,请参阅已接受的答案(不是投票最多的答案)。

这个问题是关于在iPad键盘上发现的一个行为,如果在导航控制器的模态对话框中显示,它拒绝被驳回。

基本上,如果我用下面这行来显示导航控制器:

navigationController.modalPresentationStyle = UIModalPresentationFormSheet;

键盘拒绝被忽略。如果我注释掉这一行,键盘就会消失。

...

我有两个文本字段,用户名和密码;用户名有一个下一步按钮,密码有一个完成按钮。如果我在模式导航控制器中呈现这个,键盘就不会消失。

作品

broken *b = [[broken alloc] initWithNibName:@"broken" bundle:nil];
[self.view addSubview:b.view];

不起作用

broken *b = [[broken alloc] initWithNibName:@"broken" bundle:nil];
UINavigationController *navigationController = 
[[UINavigationController alloc]
 initWithRootViewController:b];
navigationController.modalPresentationStyle = UIModalPresentationFormSheet;
navigationController.modalTransitionStyle = UIModalTransitionStyleFlipHorizontal;
[self presentModalViewController:navigationController animated:YES];
[navigationController release];
[b release];

如果我移除导航控制器部分,并将'b'单独表示为一个模态视图控制器,它可以工作。导航控制器有问题吗?

作品

broken *b = [[broken alloc] initWithNibName:@"broken" bundle:nil];
b.modalTransitionStyle = UIModalTransitionStyleFlipHorizontal;
[self presentModalViewController:b animated:YES];
[b release];

作品

broken *b = [[broken alloc] initWithNibName:@"broken" bundle:nil];
UINavigationController *navigationController = 
    [[UINavigationController alloc]
         initWithRootViewController:b];
[self presentModalViewController:navigationController animated:YES];
[navigationController release];
[b release];

当前回答

可能不是一个完美的解决方案,但有效 (自我。视图endEditing:是的); 从你的按钮或手势实现的任何地方呈现模态

其他回答

可能不返回NO,但返回YES。这样它就可以消失了。

你有一个textFieldShouldEndEditing返回YES,以及?

为什么你要解雇[nextResponder becomeFirstResponder]?!对不起,我现在明白了

我还有一些uitextview 它们都有自己的"可编辑" 属性设置为FALSE。

我们可以假设它们中没有一个标签值为secondField.tag+1吗?如果是这样,你就告诉他们成为第一响应者,而不是辞去第一响应者。也许在if结构中加入一些NSLog()。

我通过使用UIModalPresentationPageSheet演示样式来解决这个问题,并在我呈现它之后立即调整它的大小。像这样:

viewController.modalPresentationStyle = UIModalPresentationPageSheet;
viewController.modalTransitionStyle = UIModalTransitionStyleFlipHorizontal;
[self presentModalViewController:viewController animated:YES];
viewController.view.superview.autoresizingMask = 
    UIViewAutoresizingFlexibleTopMargin | 
    UIViewAutoresizingFlexibleBottomMargin;    
viewController.view.superview.frame = CGRectMake(
    viewController.view.superview.frame.origin.x,
    viewController.view.superview.frame.origin.y,
    540.0f,
    529.0f
);
viewController.view.superview.center = self.view.center;
[viewController release];

如果你用UINavigationController来显示模态,要小心。你必须在导航控制器上设置disablesautomatickeyboarddismiss,而不是在视图控制器上。你可以很容易地用分类来做到这一点。

文件:UINavigationController + KeyboardDismiss.h

#import <Foundation/Foundation.h>

@interface UINavigationController (KeyboardDismiss)

- (BOOL)disablesAutomaticKeyboardDismissal;

@end

文件:UINavigationController + KeyboardDismiss.m

#import "UINavigationController+KeyboardDismiss.h"

@implementation UINavigationController(KeyboardDismiss)

- (BOOL)disablesAutomaticKeyboardDismissal
{
    return NO;
}

@end

的文件中,不要忘记导入类别 UINavigationController。

在以模态方式呈现的视图控制器中,只需重写disablesautomatickeyboarddismiss以返回NO:

- (BOOL)disablesAutomaticKeyboardDismissal {
    return NO;
}

对于那些使用UINavigationController有问题的人,请参阅我在这里对类似问题的回答: https://stackoverflow.com/a/10507689/321785

编辑: 我认为这是对Miha Hribar的解决方案的改进(因为决策发生在它应该发生的地方),而不是Pascal关于UIViewController上的类别的评论