
本文介绍了如何在 JavaFX TableView 中检索 DatePicker 的值,并将其设置回 DatePicker 控件。核心在于理解 TableColumn 的数据类型与 DatePicker 期望的数据类型之间的匹配,以及如何进行必要的类型转换。文章提供了两种解决方案:修改 TableColumn 的数据类型为 LocalDate,或者在设置 DatePicker 值时进行日期解析。
检索 DatePicker 值并设置回 DatePicker 控件
在使用 JavaFX 开发应用程序时,经常需要在 TableView 中显示日期,并在用户选择某一行时,将该日期值设置回 DatePicker 控件。本文将详细介绍如何实现这一功能,并提供两种可行的解决方案。
问题分析
问题的核心在于 DatePicker 控件的 setValue() 方法期望接收 LocalDate 类型的数据,而 TableColumn 默认情况下可能存储的是 String 类型的数据。因此,直接使用 toString() 方法将从 TableColumn 中获取的数据传递给 setValue() 方法会导致类型不匹配的错误。
解决方案一:修改 TableColumn 的数据类型
最直接的解决方案是将 TableColumn 的数据类型修改为 LocalDate。这样,从 TableColumn 中获取的数据本身就是 LocalDate 类型,可以直接传递给 DatePicker 的 setValue() 方法。
立即学习“Java免费学习笔记(深入)”;
步骤如下:
-
修改 TableColumn 的声明:
将 TableColumn
tableColDate; 修改为 TableColumn tableColDate; -
修改 PropertyValueFactory 的设置:
确保 Booking 类中的 date 属性的类型是 LocalDate,并且 PropertyValueFactory 使用正确的属性名称。例如:
tableColDate.setCellValueFactory(new PropertyValueFactory<>("date"));其中,Booking 类应该包含一个名为 date 的 LocalDate 类型的属性,并提供相应的 getter 方法:
public class Booking { private LocalDate date; public LocalDate getDate() { return date; } public void setDate(LocalDate date) { this.date = date; } // 其他属性和方法 } -
修改 getSelected 方法:
移除 toString() 调用,直接将 tableColDate.getCellData(index) 的返回值传递给 beginDate.setValue() 方法。
@FXML void getSelected(MouseEvent event) { index = tableViewBooking.getSelectionModel().getSelectedIndex(); if (index <= -1) { return; } beginTime.setText(tableColSTime.getCellData(index).toString()); endTime.setText(tableColETime.getCellData(index).toString()); beginDate.setValue(tableColDate.getCellData(index)); // 直接传递 LocalDate 对象 reminderDesc.setText(tableColName.getCellData(index).toString()); }
示例代码:
import javafx.fxml.FXML;
import javafx.scene.control.DatePicker;
import javafx.scene.control.TableColumn;
import javafx.scene.control.TableView;
import javafx.scene.input.MouseEvent;
import java.time.LocalDate;
public class PrimaryController {
@FXML
private DatePicker beginDate;
@FXML
public TableView tableViewBooking;
@FXML
public TableColumn tableColDate;
int index = -1;
@FXML
void getSelected(MouseEvent event) {
index = tableViewBooking.getSelectionModel().getSelectedIndex();
if (index <= -1) {
return;
}
beginDate.setValue(tableColDate.getCellData(index));
}
} 解决方案二:解析日期字符串
如果无法修改 TableColumn 的数据类型,或者 TableColumn 中存储的是日期字符串,则需要在设置 DatePicker 值时,将字符串解析为 LocalDate 对象。
步骤如下:
确保 TableColumn 中存储的是符合日期格式的字符串。
-
使用 LocalDate.parse() 方法将字符串解析为 LocalDate 对象。
@FXML void getSelected(MouseEvent event) { index = tableViewBooking.getSelectionModel().getSelectedIndex(); if (index <= -1) { return; } beginTime.setText(tableColSTime.getCellData(index).toString()); endTime.setText(tableColETime.getCellData(index).toString()); beginDate.setValue(LocalDate.parse(tableColDate.getCellData(index))); // 解析字符串为 LocalDate reminderDesc.setText(tableColName.getCellData(index).toString()); }
注意事项:
- LocalDate.parse() 方法使用默认的日期格式 yyyy-MM-dd 进行解析。如果日期字符串的格式不同,需要使用 DateTimeFormatter 指定正确的格式。
- 如果日期字符串无法解析为 LocalDate 对象,LocalDate.parse() 方法会抛出 DateTimeParseException 异常。需要进行适当的异常处理。
示例代码:
import javafx.fxml.FXML;
import javafx.scene.control.DatePicker;
import javafx.scene.control.TableColumn;
import javafx.scene.control.TableView;
import javafx.scene.input.MouseEvent;
import java.time.LocalDate;
import java.time.format.DateTimeFormatter;
import java.time.format.DateTimeParseException;
public class PrimaryController {
@FXML
private DatePicker beginDate;
@FXML
public TableView tableViewBooking;
@FXML
public TableColumn tableColDate;
int index = -1;
@FXML
void getSelected(MouseEvent event) {
index = tableViewBooking.getSelectionModel().getSelectedIndex();
if (index <= -1) {
return;
}
String dateString = tableColDate.getCellData(index);
try {
// 使用 DateTimeFormatter 指定日期格式
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("dd/MM/yyyy");
LocalDate date = LocalDate.parse(dateString, formatter);
beginDate.setValue(date);
} catch (DateTimeParseException e) {
// 处理日期解析异常
System.err.println("日期解析失败: " + e.getMessage());
}
}
} 总结
本文介绍了两种从 JavaFX TableView 中检索 DatePicker 值并将其设置回 DatePicker 控件的解决方案。第一种方案是修改 TableColumn 的数据类型为 LocalDate,第二种方案是在设置 DatePicker 值时解析日期字符串。选择哪种方案取决于具体的应用场景和数据存储方式。建议优先选择第一种方案,因为它更加简洁和高效。无论选择哪种方案,都需要注意数据类型的匹配和异常处理,以确保程序的稳定性和可靠性。










