我有3个问题。
1。)因为我有多个uitextfields,我是否必须使用自己的resignFirstResponder语句设置? 2.)我会用哪种方法做到这一点? 3.)我的语法是否适合辞职第一响应者?
如果我可以在用户点击字段时关闭键盘而不是点击返回键,那将是非常好的!
我知道之前已经被问到并回答了,但老实说,我仍然有点困惑。
我正在使用故事板,使用XCode 5和iOS 7.
=============================
.h文件
@interface ViewController : UIViewController <UITextFieldDelegate,UITableViewDelegate,UITableViewDataSource>
@property (weak, nonatomic) IBOutlet UITextField *danceDate;
@property (weak, nonatomic) IBOutlet UITextField *dancePlace;
@property (weak, nonatomic) IBOutlet UITextField *danceTerminal;
@property (weak, nonatomic) IBOutlet UITextField *danceGate;
.m文件
#import "ViewController.h"
@interface ViewController ()
@end
@implementation ViewController
- (void)viewDidLoad
{
[super viewDidLoad];
[self retrieveFromParse];
self.tableView.dataSource = self;
self.tableView.delegate = self;
self.navigationItem.rightBarButtonItem = self.editButtonItem;
// SET DELEGATE HERE
//
// if I uncomment 1 of these lines, i'll get an error.
//
// _dancePlace.delegate = self;
// dancePlace.delegate = self;
// dancePlace = self;
}
- (void)textFieldDidBeginEditing:(UITextField *)textField
{
}
-(BOOL) textFieldShouldReturn: (UITextField *) textField
{
[textField resignFirstResponder];
return YES;
}
-(BOOL) textFieldShouldReturn: (UITextField *) textField
{
return YES;
}
答案 0 :(得分:40)
尝试以下方法:
[[self view] endEditing:YES]
答案 1 :(得分:33)
辞去textField: 您的所有textField.delegate都应设置为ViewController的对象。 然后实现下面的委托方法。
-(BOOL) textFieldShouldReturn: (UITextField *) textField {
[textField resignFirstResponder];
return YES;
}
点击视图时关闭键盘: 在ViewController.view中添加一个Tap手势,如下所示:
//declare a property to store your current responder
@property (nonatomic, assign) id currentResponder;
//in viewDidLoad:
UITapGestureRecognizer *singleTap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(resignOnTap:)];
[singleTap setNumberOfTapsRequired:1];
[singleTap setNumberOfTouchesRequired:1];
[self.view addGestureRecognizer:singleTap];
[singleTap release];
//Implement the below delegate method:
- (void)textFieldDidBeginEditing:(UITextField *)textField {
self.currentResponder = textField;
}
//Implement resignOnTap:
- (void)resignOnTap:(id)iSender {
[self.currentResponder resignFirstResponder];
}
// was missing ; after the call --> [self.currentResponder resignFirstResponder]
// also in textFieldDidEndEditing set self.currentResponder = nil;
答案 2 :(得分:4)
-(BOOL) textFieldShouldReturn: (UITextField *) textField{
[textField resignFirstResponder];
return YES;
}
还会关联您的UITextField
代表。
答案 3 :(得分:4)
此答案适用于iOS 7和arc,
关闭键盘: 在ViewController中添加以下操作
-(IBAction)textFieldReturn:(id)sender { [sender resignFirstResponder]; }
接下来,在main.storyboard中选择textField并从连接检查器中选择 控制+拖动&#34;结束退出&#34;事件到视图控制器。
关闭键盘: 在ViewController中实现以下方法
- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event { UITouch *touch = [[event allTouches] anyObject]; if ([YOUR_TEXT_FIELD isFirstResponder] && [touch view] != YOUR_TEXT_FIELD) { [YOUR_TEXT_FIELD resignFirstResponder]; } [super touchesBegan:touches withEvent:event]; }
答案 4 :(得分:4)
这是我在代码中使用的内容。它效果很好,比其他答案更有效。
在yourviewcontroller.h中添加:
@property (nonatomic) UITapGestureRecognizer *tapRecognizer;
现在在.m文件中,将其添加到ViewDidLoad函数:
- (void)viewDidLoad {
//Keyboard stuff
tapRecognizer = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(didTapAnywhere:)];
tapRecognizer.cancelsTouchesInView = NO;
[self.view addGestureRecognizer:tapRecognizer];
}
另外,在.m文件中添加此功能:
- (void)handleSingleTap:(UITapGestureRecognizer *) sender
{
[self.view endEditing:YES];
}
答案 5 :(得分:1)
当有问题的UITextField
调用 - (BOOL)textFieldShouldReturn:(UITextField*)textField
的委托方法时,它会将自身作为参数传递。
因此,作为此方法的参数的特定textField
是您关心的特定参数。在此委托方法中,您可以将其称为“textField”。
这意味着您应该使用Mirko Catalano建议在resignFirstResponder
上调用textField
而不是像您正在进行的各个属性。
Mirko建议验证代表确实已被分配也是至关重要的。您需要确保nib或storyboard中的所有UITextField都具有指向File的所有者的委托属性。否则,委托消息将无处可及,并立即被忽略!
答案 6 :(得分:1)
尝试使用self.dancePlace.delegate = self;
代替dancePlace.delegate = self;
来设置UITextFieldDelegate。这有用吗?
答案 7 :(得分:0)
在swift 3中:
//Dismiss keyboard , When touch outside
override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?)
{
self.view.endEditing(true)
}