观察UIDatePicker中的更改

问题描述 投票:36回答:4

我注意到没有代表观察UIDatePicker中的更改。有没有办法检测何时在选择器中进行更改而不确认任何内容,例如它旋转并落在我希望能够检测到的新数字上的那一刻。我考虑过关键值观察,但我不认为有一个属性会在现场发生变化

objective-c ios uidatepicker key-value-observing
4个回答
42
投票

转到IB并从UIDatePicker拖动到.h文件。然后选择

在你的.m文件中处理这个你想要的; XCode将为您添加以下方法。


65
投票

您需要向您的UIDatePicker添加UIControlEventValueChanged事件以处理日期更改:

[myDatePicker addTarget:self action:@selector(dateIsChanged:) forControlEvents:UIControlEventValueChanged];

然后执行:

- (void)dateIsChanged:(id)sender{
     NSLog(@"Date changed");
}

2
投票

以下是符合KVO标准的日期选择器的提案:

@interface LNKVODatePicker : UIDatePicker

@end

@implementation LNKVODatePicker

- (void)willMoveToWindow:(UIWindow *)newWindow
{
    [super willMoveToWindow:newWindow];

    [self removeTarget:self action:@selector(_didChangeDate) forControlEvents:UIControlEventValueChanged];

    if(newWindow != nil)
    {
        [self addTarget:self action:@selector(_didChangeDate) forControlEvents:UIControlEventValueChanged];
    }
}

- (void)dealloc
{
    [self removeTarget:self action:@selector(_didChangeDate) forControlEvents:UIControlEventValueChanged];
}

- (void)_didChangeDate
{
    [self willChangeValueForKey:@"date"];
    [self didChangeValueForKey:@"date"];
}

@end

1
投票

Swift 4.2 | Xcode 10.1

@objc func handleDatePicker(_ datePicker: UIDatePicker) {
    textField.text = datePicker.date.formatted
}

override func viewDidLoad() {
    super.viewDidLoad()
    datePicker.addTarget(self, action: #selector(handleDatePicker), for: .valueChanged)
}

extension Date {
    static let formatter: DateFormatter = {
        let formatter = DateFormatter()
        formatter.dateFormat = "EEEE, dd MMM yyyy HH:mm:ss Z"
        return formatter
    }()
    var formatted: String {
        return Date.formatter.string(from: self)
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.