16

这让我困惑了一段时间,我似乎无法理解它。我正在使用单元格值工厂来填充一个简单的单列表,但它没有填充到表中。

它确实如此,我单击填充的行,但我没有看到其中的任何值——在本例中为字符串值。[我只是编辑了这个以使其更清晰]

我有一个不同的项目,它在同一种数据模型下工作。我究竟做错了什么?

这是代码。最后的注释代码似乎有效。我检查了是否存在常见的错误——创建一个新的列实例或一个新的 tableview 实例。没有什么。请帮忙!


//简单数据模型 Stock.java

public class Stock {

    private SimpleStringProperty stockTicker;

    public Stock(String stockTicker) {
        this.stockTicker = new SimpleStringProperty(stockTicker);
    }

    public String getstockTicker() {
        return stockTicker.get();
    }

    public void setstockTicker(String stockticker) {
        stockTicker.set(stockticker);
    }
}

//控制器类 MainGuiController.java

    private ObservableList<Stock> data;
    @FXML
    private TableView<Stock> stockTableView;// = new TableView<>(data);
    @FXML
    private TableColumn<Stock, String> tickerCol;


    private void setTickersToCol() {
    try {
        Statement stmt = conn.createStatement();//conn is defined and works
        ResultSet rsltset = stmt.executeQuery("SELECT ticker FROM tickerlist order by ticker");
        data = FXCollections.observableArrayList();
        Stock stockInstance;
        while (rsltset.next()) {
            stockInstance = new Stock(rsltset.getString(1).toUpperCase());
            data.add(stockInstance);
        }
    } catch (SQLException ex) {
        Logger.getLogger(WriteToFile.class.getName()).log(Level.SEVERE, null, ex);
        System.out.println("Connection Failed! Check output console");
    }

    tickerCol.setCellValueFactory(new PropertyValueFactory<Stock,String>("stockTicker"));
    stockTableView.setItems(data);
    }

    /*THIS, ON THE OTHER HAND, WORKS*/
    /*Callback<CellDataFeatures<Stock, String>, ObservableValue<String>> cellDataFeat =
            new Callback<CellDataFeatures<Stock, String>, ObservableValue<String>>() {
        @Override
        public ObservableValue<String> call(CellDataFeatures<Stock, String> p) {
            return new SimpleStringProperty(p.getValue().getstockTicker());
        }
    };*/
4

2 回答 2

45
建议的解决方案(使用 Lambda,而不是 PropertyValueFactory)

代替:

aColumn.setCellValueFactory(new PropertyValueFactory<Appointment,LocalDate>("date"));

写:

aColumn.setCellValueFactory(cellData -> cellData.getValue().dateProperty());

有关更多信息,请参阅此答案:


使用 PropertyValueFactory 的解决方案

上面概述的 lambda 解决方案是首选,但如果您希望使用 PropertyValueFactory,此替代解决方案提供了相关信息。

如何修复它

您的 getter 和 setter 方法的情况是错误的。

getstockTicker应该getStockTicker

setstockTicker应该setStockTicker

一些背景信息

您的 PropertyValueFactory 保持不变:

new PropertyValueFactory<Stock,String>("stockTicker")

当您还向 Stock 类添加属性访问器时,命名约定将显得更加明显:

public class Stock {

    private SimpleStringProperty stockTicker;

    public Stock(String stockTicker) {
        this.stockTicker = new SimpleStringProperty(stockTicker);
    }

    public String getStockTicker() {
        return stockTicker.get();
    }

    public void setStockTicker(String stockticker) {
        stockTicker.set(stockticker);
    }

    public StringProperty stockTickerProperty() {
        return stockTicker;
    }
}

PropertyValueFactory 使用反射来查找相关的访问器(这些应该是公共的)。首先,它将尝试使用 stockTickerProperty 访问器,如果不存在,则回退到 getter 和 setter。建议提供属性访问器,因为这样您将自动启用表来观察基础模型中的属性,并随着基础模型的变化动态更新其数据。

于 2013-06-11T05:35:53.980 回答
-2

将 Getter 和 Setter 方法放入所有元素的数据类中。

于 2016-12-29T18:00:35.283 回答