我们尝试验证javafx日期选择器。所以我们使用:
if (fromDatePicker.getValue() == null) {
sb.append("No valid from date!n");
} else {
System.out.println(fromDatePicker.getValue().toString());
if (!DateUtil
.validEnglishDate(fromDatePicker.getValue().toString())) {
sb.append("No valid from date. Use the format yyyy-MM-dd.n");
}
}
但目前无法使用日期选择器获取无效日期,因为所有无效日期都会更改为起始值。因此,我们询问我们是否可以使用javafx日期选择器获取无效日期?
*****编辑*****
示例:我们有以下日期选择器:DatePicker〔2015-05-12〕现在我们在DatePicker中输入了"fjdfk",因此我们有:日期选择器[fjdfk]保存数据时,日期选择器自动更改为datepicker〔2015-05-12〕
您可以使用DatePicker#setConverter(StringConverter<LocalDate>)
捕获任何解析异常并警告用户。这是一个示例:
public class SecureLocalDateStringConverter extends StringConverter<LocalDate> {
/**
* The date pattern that is used for conversion. Change as you wish.
*/
private static final String DATE_PATTERN = "dd/MM/yyyy";
/**
* The date formatter.
*/
public static final DateTimeFormatter DATE_FORMATTER =
DateTimeFormatter.ofPattern(DATE_PATTERN);
private boolean hasParseError = false;
public boolean hasParseError(){
return hasParseError;
}
@Override
public String toString(LocalDate localDate) {
return DATE_FORMATTER.format(localDate);
}
@Override
public LocalDate fromString(String formattedString) {
try {
LocalDate date=LocalDate.from(DATE_FORMATTER.parse(formattedString));
hasParseError=false;
return date;
} catch (DateTimeParseException parseExc){
hasParseError=true;
return null;
}
}
}
在您的控制下,您只需调用converter#hasParseError()
,converter
就是您用DatePicker#setConverter(StringConverter<LocalDate>)
设置的。