工具栏上一个和下一个按钮逻辑

Posted

技术标签:

【中文标题】工具栏上一个和下一个按钮逻辑【英文标题】:toolbar previous and next button logic 【发布时间】:2012-10-11 03:38:04 【问题描述】:

我正在使用以下代码使用 UITextField 委托移动到下一个字段,并且我正在向键盘添加一个带有上一个、下一个和确定按钮的工具栏。代码运行良好。

就像您看到的键盘返回按钮逻辑非常通用,使用 UITextField 标记,这很好,因为我将使用这段代码。现在我需要编写上一个和下一个按钮的逻辑,我迷路了。有什么想法吗?

更新(完整的代码,经过一些修改,感谢@8vius 在聊天中花了一些时间与我一起使它工作):

//
// SigninViewController.m
//

#import "SigninViewController.h"

@implementation SigninViewController

@synthesize firstResponder = _firstResponder;
@synthesize toolbar;
@synthesize email;
@synthesize password;

- (void)move:(UIBarButtonItem*)sender 

    NSInteger tag = self.firstResponder.tag;

    if ([sender.title isEqualToString:@"Anterior"]) 
        tag -= 1;
     else if ([sender.title isEqualToString:@"Próximo"]) 
        tag += 1;
    

    UITextField *nextTextField = (UITextField*)[self.view viewWithTag:tag];

    if (nextTextField && tag > 0) 
        [nextTextField becomeFirstResponder];
     else 
        [self.firstResponder resignFirstResponder];
        self.firstResponder = nil;
    



- (void)ok:(id)sender 
    [self.view endEditing:YES];
    self.firstResponder = nil;


- (void)textFieldDidBeginEditing:(UITextField*)textField 
    self.firstResponder = textField;


- (BOOL)textFieldShouldReturn:(UITextField*)textField 

    NSInteger tag = textField.tag + 1;

    UITextField *nextTextField = (UITextField*)[self.view viewWithTag:tag];

    if (nextTextField) 
        [nextTextField becomeFirstResponder];
     else 
        [textField resignFirstResponder];
        self.firstResponder = nil;
    

    return NO;



- (void)viewDidLoad 

    [super viewDidLoad];

    self.email.delegate = self;
    self.password.delegate = self;

    if (self.toolbar == nil)
    
        self.toolbar = [[UIToolbar alloc] initWithFrame:CGRectMake(0, 0, self.view.bounds.size.width, 44)];

        UIBarButtonItem* previous = [[UIBarButtonItem alloc] initWithTitle:@"Anterior" style:UIBarButtonItemStyleBordered target:self action:@selector(move:)];
        UIBarButtonItem* next = [[UIBarButtonItem alloc] initWithTitle:@"Próximo" style:UIBarButtonItemStyleBordered target:self action:@selector(move:)];
        UIBarButtonItem* space = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:(UIBarButtonSystemItemFlexibleSpace) target:nil action:nil];
        UIBarButtonItem* ok = [[UIBarButtonItem alloc] initWithTitle:@"Ok" style:UIBarButtonItemStyleBordered target:self action:@selector(ok:)];

        [self.toolbar setItems:[[NSArray alloc] initWithObjects:previous, next, space, ok, nil]];

        [self.toolbar setTranslucent:YES];
        [self.toolbar setTintColor:[UIColor blackColor]];
    

    for (UIView* view in self.view.subviews) 
        if ([view isKindOfClass:[UITextField class]]) 
            [(UITextField*)view setInputAccessoryView:toolbar];
        
    



- (void)viewDidUnload 
    self.email = nil;
    self.password = nil;
    [super viewDidUnload];


@end

【问题讨论】:

【参考方案1】:

这很简单,当您加载视图时,根据您希望它们的顺序在文本字段上设置 tag 属性,然后您只需遍历字段上的标记元素:

- (void)toggleTextfield:(UIBarButtonItem *)sender 
  NSInteger nextTag = self.firstResponder.tag;
  if ([sender.title isEqualToString:@"Previous"] && nextTag > 1) 
    nextTag -= 1
   else if ([sender.title isEqualToString:@"Next"]) 
    nextTag += 1;
  

  UITextField *nextTextField = (UITextField *)[self.view viewWithTag:nextTag];
  if (nextTextField) 
    [nextTextField becomeFirstResponder];
  

并跟踪谁是第一响应者:

-(void)textFieldDidBeginEditing:(UITextField *)textField 
  self.firstResponder = textField;


- (BOOL)textFieldShouldReturn:(UITextField *)textField 
  [textField resignFirstResponder];
  self.firstResponder = nil;
  return YES;

当您加载视图时,您会将按钮绑定到切换操作:

  UIBarButtonItem *previousButton = [[UIBarButtonItem alloc] initWithTitle:@"Previous" 
                                                                     style:UIBarButtonItemStyleBordered 
                                                                    target:self
                                                                    action:@selector(toggleTextfield:)];
  UIBarButtonItem *nextButton = [[UIBarButtonItem alloc] initWithTitle:@"Next" 
                                                                     style:UIBarButtonItemStyleBordered 
                                                                    target:self
                                                                    action:@selector(toggleTextfield:)];

例如,在我的例子中,我在表格视图中设置了我的文本字段,所以在我的cellForRowAtIndexPath 方法中,我将tag 属性设置为rowrow

编辑:您必须设置firstResponder 属性才能使其工作。

在您的 .h 文件中:

@property UIView *firstResponder

在您的 .m 文件中:

@synthesize firstResponder = _firstResponder;

【讨论】:

我对 ios 很陌生,所以我正在尝试学习(从)你的代码,但我已经要感谢你了,我相信它可以工作。只有一个问题:如果我将 textFieldShouldReturn 更改为您的代码,键盘返回按钮仍然有效吗? 是的,它会起作用,这与我在自己的应用程序中使用的设置相同。您仍然可以只使用您的代码和我的代码的混合体,因为您将视图设置为第一响应者而我没有。如果您是新手,我还建议您查看斯坦福的 iPhone 和 iPad 开发 CS193P 课程,您可以在 iTunes U 上找到它,这是开始正确掌握 iOS 开发概念的好方法。跨度> 这是课程链接itunes.apple.com/us/itunes-u/…。 我在 NSInteger nextTag = self.firstResponder.tag; 中遇到错误,它说我的班级中没有 firstResponder。 哦,是的,你必须设置属性,很抱歉错过了,让我编辑我的答案。

以上是关于工具栏上一个和下一个按钮逻辑的主要内容,如果未能解决你的问题,请参考以下文章

Datepicker 上一个和下一个按钮图像问题

网格面板中的 ExtJs 5.1 分页工具栏

将上一个和下一个按钮添加到 li item php 或 jquery

滑动滑块的自定义上一个和下一个按钮

在android studio中使用上一个和下一个按钮打开不同的pdf文件?

上一个和下一个按钮不相邻