首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

将TextField文本设置为TableView列中的数据

,可以通过以下步骤实现:

  1. 首先,确保你已经创建了一个TableView,并且已经定义了列(Column)。
  2. 在TableView的列定义中,使用CellFactory来自定义单元格的显示方式。可以使用Lambda表达式或者匿名内部类来实现。
  3. 在CellFactory中,创建一个TextField,并将其与单元格绑定。
  4. 为TextField添加一个事件监听器,监听文本变化事件。
  5. 在事件监听器中,获取TextField的文本,并将其设置为TableView列中对应行的数据。

下面是一个示例代码,演示了如何将TextField文本设置为TableView列中的数据:

代码语言:txt
复制
import javafx.application.Application;
import javafx.beans.property.SimpleStringProperty;
import javafx.beans.value.ChangeListener;
import javafx.beans.value.ObservableValue;
import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.scene.Scene;
import javafx.scene.control.*;
import javafx.scene.control.cell.PropertyValueFactory;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;

public class Main extends Application {

    private TableView<Person> tableView;
    private ObservableList<Person> data;

    public static void main(String[] args) {
        launch(args);
    }

    @Override
    public void start(Stage primaryStage) {
        // 创建数据
        data = FXCollections.observableArrayList(
                new Person("John", "Doe"),
                new Person("Jane", "Smith"),
                new Person("Bob", "Johnson")
        );

        // 创建TableView和列
        tableView = new TableView<>();
        TableColumn<Person, String> firstNameCol = new TableColumn<>("First Name");
        TableColumn<Person, String> lastNameCol = new TableColumn<>("Last Name");

        // 设置列的数据源
        firstNameCol.setCellValueFactory(new PropertyValueFactory<>("firstName"));
        lastNameCol.setCellValueFactory(new PropertyValueFactory<>("lastName"));

        // 设置列的CellFactory
        firstNameCol.setCellFactory(column -> {
            return new TableCell<Person, String>() {
                private TextField textField;

                @Override
                protected void updateItem(String item, boolean empty) {
                    super.updateItem(item, empty);

                    if (empty) {
                        setGraphic(null);
                    } else {
                        if (isEditing()) {
                            if (textField != null) {
                                textField.setText(getString());
                            }
                            setGraphic(textField);
                            setContentDisplay(ContentDisplay.GRAPHIC_ONLY);
                        } else {
                            setText(getString());
                            setContentDisplay(ContentDisplay.TEXT_ONLY);
                        }
                    }
                }

                @Override
                public void startEdit() {
                    super.startEdit();

                    if (textField == null) {
                        createTextField();
                    }

                    setText(null);
                    setGraphic(textField);
                    textField.selectAll();
                }

                @Override
                public void cancelEdit() {
                    super.cancelEdit();

                    setText(getString());
                    setContentDisplay(ContentDisplay.TEXT_ONLY);
                }

                @Override
                public void commitEdit(String newValue) {
                    super.commitEdit(newValue);

                    Person person = getTableView().getItems().get(getIndex());
                    person.setFirstName(newValue);
                }

                private void createTextField() {
                    textField = new TextField(getString());
                    textField.setMinWidth(this.getWidth() - this.getGraphicTextGap() * 2);
                    textField.focusedProperty().addListener((observable, oldValue, newValue) -> {
                        if (!newValue) {
                            commitEdit(textField.getText());
                        }
                    });
                }

                private String getString() {
                    return getItem() == null ? "" : getItem();
                }
            };
        });

        // 将列添加到TableView中
        tableView.getColumns().addAll(firstNameCol, lastNameCol);

        // 将数据添加到TableView中
        tableView.setItems(data);

        // 创建一个垂直布局,并将TableView添加到其中
        VBox vbox = new VBox(tableView);

        // 创建一个场景,并将布局添加到场景中
        Scene scene = new Scene(vbox);

        // 设置舞台的场景,并显示舞台
        primaryStage.setScene(scene);
        primaryStage.show();
    }

    public static class Person {
        private final SimpleStringProperty firstName;
        private final SimpleStringProperty lastName;

        public Person(String firstName, String lastName) {
            this.firstName = new SimpleStringProperty(firstName);
            this.lastName = new SimpleStringProperty(lastName);
        }

        public String getFirstName() {
            return firstName.get();
        }

        public void setFirstName(String firstName) {
            this.firstName.set(firstName);
        }

        public String getLastName() {
            return lastName.get();
        }

        public void setLastName(String lastName) {
            this.lastName.set(lastName);
        }
    }
}

在这个示例中,我们创建了一个包含两列的TableView,分别是"First Name"和"Last Name"。我们将"First Name"列的单元格定义为可编辑的TextField,并将其与对应行的数据绑定。当用户编辑TextField中的文本时,会自动更新对应行的数据。

这个示例中使用了JavaFX框架来实现,JavaFX是一种用于构建富客户端应用程序的开发工具包。在实际开发中,你可以根据自己的需求选择适合的开发框架和技术栈。

推荐的腾讯云相关产品:腾讯云云服务器(CVM)和腾讯云数据库(TencentDB)。你可以通过以下链接了解更多关于这些产品的信息:

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

27分3秒

第 7 章 处理文本数据(1)

2分11秒

2038年MySQL timestamp时间戳溢出

7分5秒

MySQL数据闪回工具reverse_sql

3分52秒

AIoT应用创新大赛-基于TencentOS Tiny 的介绍植物生长分析仪视频

1分32秒

最新数码印刷-数字印刷-个性化印刷工作流程-教程

4分36秒

PS小白教程:如何在Photoshop中制作雨天玻璃文字效果?

1分7秒

PS小白教程:如何在Photoshop中给风景照添加光线效果?

1分19秒

020-MyBatis教程-动态代理使用例子

14分15秒

021-MyBatis教程-parameterType使用

3分49秒

022-MyBatis教程-传参-一个简单类型

7分8秒

023-MyBatis教程-MyBatis是封装的jdbc操作

8分36秒

024-MyBatis教程-命名参数

领券