0

resignFirstResponder用来隐藏数字键盘,但它只在隐藏键盘的某些时候起作用:我backgroundTap[textField resignFirstResponder];背景点击实现了键盘确实是隐藏的。我还在 中添加了这一行viewWillDisappear,但它在某些时候有效。当用户回到他来自的窗口时,键盘消失了。但是当他进入一个新窗口(不是他来自的那个)时,键盘并没有消失。我使用方法检查了调试isFirstResponder,在这两种情况下,文本字段确实不再是第一响应者(尽管在其中一种情况下,键盘一直显示,如前所述)。

的实现viewWillDisappear是这样的:

- (void)viewWillDisappear:(BOOL)animated
{
    [super viewWillDisappear:animated];

    [textField resignFirstResponder];
    [self.view endEditing:YES];
}

我想在 viewWillDisappear 两种情况下都隐藏键盘,因为新窗口没有与此键盘相关的文本字段。它有完全不同的元素。

推送另一个视图的事件不是单击按钮,而是开始编辑文本字段。我的视图中有三个文本字段,其中只有一个显示键盘。另外两个推动了另一种观点。这是 textFieldDidBeginEditing 的代码:

-(void)textFieldDidBeginEditing:(UITextField *)textField{
    if (textField1.editing == YES)
    {
        [self performSegueWithIdentifier:@"goToView1" sender:self];
     }
    else if (textField2.editing == YES)
    {
        [self performSegueWithIdentifier:@"goToView2" sender:self];
    }

}

而生成键盘的文本字段是 textField3。

关于如何在这两种情况下使键盘消失的一些想法?

4

2 回答 2

0
- (BOOL)textFieldShouldBeginEditing:(UITextField *)textField
{
     if (textField == textField1)
     {
         [self.view endEditing:YES]; 
         //else you can try with this also.
         [textField performSelector:@selector(resignFirstResponder)
                withObject:nil
                afterDelay:0];
         //
         [self performSegueWithIdentifier:@"goToView1" sender:self];
         return NO;
     }
     else if (textField == textField2)
     {
         [self.view endEditing:YES];
         [self performSegueWithIdentifier:@"goToView2" sender:self];
         return NO;
     }
    return YES;
}
于 2013-04-03T13:43:50.003 回答
0

使用此代码检查是否存在任何文本字段并使用它来关闭键盘。根据您的需要进行调整。

for (id elem in self.view.subviews) {
    if ([elem isKindOfClass:[UITextField class]]) {
        [(UITextField *)elem resignFirstResponder];
    }
}
于 2013-04-03T14:07:09.397 回答