在UITableViewCell内的UITextField中编辑NSManagedObject

时间:2012-04-02 14:00:31

标签: ios core-data uitableview uitextfield

我有一个非常简单的RootView控制器 - >详细信息视图控制器,用于显示核心数据对象的列表,并在DetailViewController中显示所选对象的详细信息。 DetailViewController是一个带有自定义UITableViewCell的UITableView,它有一个允许用户编辑的UITextField。 我能够显示表格,能够编辑文本字段等。但是,一旦用户选择“完成”按钮或取消“取消”按钮操作后的更改,我不确定如何实际更新管理对象。 我知道我可以通过使用EditViewController实现这一点,EditViewController可以用来一次编辑一个属性。但是,我对可以在DetailViewController中支持内联编辑的解决方案感兴趣。任何建议都会非常有用。

谢谢,

自定义UITableView单元代码

- (id)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier
{
    self = [super initWithStyle:style reuseIdentifier:reuseIdentifier];
    if (self) {
        self.selectionStyle = UITableViewCellSelectionStyleNone;

        _textField = [[UITextField alloc] initWithFrame:CGRectZero];
        [_textField setTextAlignment:UITextAlignmentLeft];
        [_textField setReturnKeyType:UIReturnKeyDone];
        [_textField setClearButtonMode:UITextFieldViewModeWhileEditing];
        [_textField setDelegate:self];
        [[self contentView] addSubview:_textField];
    }
    return self;
}

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

    // Configure the view for the selected state
}

-(void) layoutSubviews {
    [super layoutSubviews];
    CGRect contentRect = [self.contentView bounds];

    // In this example we will never be editing, but this illustrates the appropriate pattern

    if ([self isEditing]) {
        self.textLabel.frame = CGRectZero;
        self.textField.frame = CGRectMake(contentRect.origin.x + kCellLeftOffset, kCellTopOffset, contentRect.size.width - kCellLeftOffset, kCellHeight);
    }
    else {
        CGRect frame = CGRectMake(contentRect.origin.x + kCellLeftOffset, kCellTopOffset, 90, kCellHeight);
        CGRect textFrame = CGRectMake(frame.origin.x + frame.size.width + kCellLeftOffset, kCellTopOffset, 180, kCellHeight);

        self.textLabel.frame = frame;
        self.textField.frame = textFrame;
    }
}

- (void)setEditing:(BOOL)editing animated:(BOOL)animated {
    [super setEditing:editing animated:animated];
    if (!editing)
        [_textField resignFirstResponder];
}

-(BOOL) textFieldShouldBeginEditing:(UITextField *)textField {
    return [self isEditing];
}

1 个答案:

答案 0 :(得分:0)

文本编辑应该在控制器而不是视图中处理。您的自定义单元格是一个视图,放置文本字段委托方法的适当位置将是详细视图控制器。

以下是您的解决方案:

将根视图控制器的managedObjectModel作为属性传递给详细视图控制器。对要编辑的托管对象执行相同操作。

在文本字段的委托方法中,根据需要更新对象的属性

- (void)textFieldDidEndEditing:(UITextField *)textField {
   self.managedObject.textAttribute = textField.text;
}

最后,在DoneCancel按钮的处理程序中,保存或放弃更改:

-(void)cancel {
   [self.managedObjectContext rollback];
   [self dismissModalViewControllerAnimated:YES];  // or pop
}

-(void)done {
   [self.managedObjectContext save:nil]; // better use proper error handling
   [self dismissModalViewControllerAnimated:YES];  // or pop
}