- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试提交一个 TableCell
,但正在调用 cancelEdit()
。只有当我通过调用 tableView.edit()
使 cell
进入编辑状态时才会发生这种情况。
我通过以下方式调用 editCommit()
:
private void handleKeyPressed(KeyEvent e) {
if (e.getCode() == KeyCode.ENTER) {
commitEdit(textField.getText());
}
}
为什么在按下回车键时调用 cancelEdit()
?手动单击添加的空白行并尝试通过按 enter 键提交单元格可以正常工作。
import java.util.function.Function;
import javafx.application.Application;
import javafx.beans.property.StringProperty;
import javafx.collections.FXCollections;
import javafx.stage.Stage;
import javafx.scene.Scene;
import javafx.scene.layout.BorderPane;
import javafx.scene.layout.VBox;
import javafx.scene.control.TableView;
import javafx.scene.control.Button;
import javafx.scene.control.ContentDisplay;
import javafx.scene.control.TableCell;
import javafx.scene.control.TableColumn;
import javafx.scene.control.TextField;
import javafx.scene.input.KeyCode;
import javafx.scene.input.KeyEvent;
import javafx.beans.property.SimpleStringProperty;
public class Main extends Application {
@Override
public void start(Stage primaryStage) {
BorderPane root = new BorderPane();
primaryStage.setScene(new Scene(root, 400, 400));
primaryStage.show();
root.setCenter(new TableExample());
}
public class TableExample extends VBox {
public TableExample() {
TableView<Building> tableView = new TableView<>();
tableView.setEditable(true);
//adds a new blank row to table;
Button add = new Button("add");
add.setOnAction(e -> {
Building newBuilding = new Building();
tableView.getItems().add(0, newBuilding);
tableView.edit(0, tableView.getColumns().get(0));
//I tried focusing and selecting the row
//but does not help.
tableView.getFocusModel().focus(0);
tableView.getSelectionModel().select(0);
});
getChildren().addAll(add, tableView);
Building building = new Building();
building.setName("Building 100");
Function<Building, StringProperty> property = Building::nameProperty;
TableColumn<Building, String> column = new TableColumn<>("name");
column.setEditable(true);
column.setCellValueFactory(cellData -> property.apply(cellData.getValue()));
column.setCellFactory(p -> new EditingStringCell<>());
tableView.getColumns().add(column);
tableView.setItems(FXCollections.observableArrayList(building));
}
}
public class EditingStringCell<S, T> extends TableCell<Building, String> {
private TextField textField;
public EditingStringCell() {
setEditable(true);
}
@Override
protected void updateItem(String item, boolean empty) {
super.updateItem(item, empty);
setText(empty ? null : item);
}
@Override
public void startEdit() {
System.out.println("start edit");
super.startEdit();
buildControl(getItem());
setContentDisplay(ContentDisplay.GRAPHIC_ONLY);
}
private void buildControl(String item) {
System.out.println("item: " + item);
textField = new TextField();
textField.addEventHandler(KeyEvent.KEY_RELEASED,
this::handleKeyPressed);
textField.setText(item == null ? "" : (item));
setContentDisplay(ContentDisplay.GRAPHIC_ONLY);
setGraphic(textField);
}
//whenever pressing enter on a new "blank" row
//cancelEdit() gets called. But if you try again
//it works.
private void handleKeyPressed(KeyEvent e) {
if (e.getCode() == KeyCode.ENTER) {
commitEdit(textField.getText());
}
}
@Override
public void cancelEdit() {
System.out.println("cancel edit");
super.cancelEdit();
setContentDisplay(ContentDisplay.TEXT_ONLY);
}
@Override
public void commitEdit(String newValue) {
System.out.println("commited: " + newValue);
super.commitEdit(newValue);
setContentDisplay(ContentDisplay.TEXT_ONLY);
}
}
public class Building {
private final StringProperty name = new SimpleStringProperty();
public StringProperty nameProperty() {
return name;
}
public String getName() {
return name.get();
}
public void setName(String name) {
this.name.set(name);
}
}
public static void main(String[] args) {launch(args);}
}
最佳答案
基本上,当涉及到 terminating an on-going edit 时,TableView(和其他虚拟化控件)表现得非常糟糕: 大多数情况下,当可用性需要提交时,它会取消编辑。
在您的示例中,有两个不同的(众所周知的)原因
为了看看,我在你的代码中添加了一些打印:
演示问题 1:
打印输出:
start edit 0 on id: 2
before adding: TablePosition [ row: 0, column: ... ]
cancel edit 0 on id: 2
start edit 0 on id: 2
start edit 0 on id: 14 // <- some slightly weird cell re-use
cancel edit 12 on id: 2 // <- triggers a cancel on the old, functional interference unknown
演示问题 2:
打印出来:
before starting edit on : 1
start edit 1 on id: 13
cancel edit 0 on id: 14
...不幸的是,没有什么可以做的(甚至没有)...
您的示例略有修改:
import java.util.function.Function;
import javafx.application.Application;
import javafx.beans.property.SimpleStringProperty;
import javafx.beans.property.StringProperty;
import javafx.collections.FXCollections;
import javafx.event.ActionEvent;
import javafx.scene.Parent;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.control.ContentDisplay;
import javafx.scene.control.TableCell;
import javafx.scene.control.TableColumn;
import javafx.scene.control.TablePosition;
import javafx.scene.control.TableView;
import javafx.scene.control.TextField;
import javafx.scene.input.KeyCode;
import javafx.scene.input.KeyEvent;
import javafx.scene.layout.BorderPane;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;
/**
* https://stackoverflow.com/q/46396423/203657
*/
public class TableEditSO extends Application {
@Override
public void start(Stage primaryStage) {
BorderPane root = new BorderPane();
primaryStage.setScene(new Scene(root, 400, 400));
primaryStage.show();
//root.setCenter(new TableExample());
root.setCenter(getContent());
}
private Parent getContent() {
TableView<Building> tableView = new TableView<>();
tableView.setEditable(true);
//adds a new blank row to table;
Button add = new Button("add");
add.setOnAction(e -> {
Building newBuilding = new Building();
// modifications to the items will cancel an edit
System.out.println("before adding: " + tableView.getEditingCell());
tableView.getItems().add(0, newBuilding);
tableView.edit(0, tableView.getColumns().get(0));
//I tried focusing and selecting the row
//but does not help.
tableView.getFocusModel().focus(0);
tableView.getSelectionModel().select(0);
});
Button edit = new Button("edit");
edit.setOnAction(e -> {
int size = tableView.getItems().size();
if (size < 2) return;
TablePosition pos = tableView.getEditingCell();
int last = size - 1;
if (pos != null) {
int row = pos.getRow();
if (row == last) {
//make certain we switch editing to another row
last--;
}
}
System.out.println("before starting edit on : " + last);
// starting edit on another item will cancel an edit
tableView.edit(last, tableView.getColumns().get(0));
});
Building building = new Building();
building.setName("Building 100");
Function<Building, StringProperty> property = Building::nameProperty;
TableColumn<Building, String> column = new TableColumn<>("name");
column.setEditable(true);
column.setCellValueFactory(cellData -> property.apply(cellData.getValue()));
column.setCellFactory(p -> new EditingStringCell<>());
tableView.getColumns().add(column);
tableView.setItems(FXCollections.observableArrayList(building));
VBox box = new VBox(10, add, edit, tableView);
return box;
}
// don't extend without functional reason
public class TableExample extends VBox {
public TableExample() {
TableView<Building> tableView = new TableView<>();
tableView.setEditable(true);
//adds a new blank row to table;
Button add = new Button("add");
add.setOnAction(e -> {
Building newBuilding = new Building();
System.out.println("before adding: " + tableView.getEditingCell());
tableView.getItems().add(0, newBuilding);
System.out.println("after adding: " + tableView.getEditingCell());
tableView.edit(0, tableView.getColumns().get(0));
System.out.println("after starting: " + tableView.getEditingCell());
//I tried focusing and selecting the row
//but does not help.
tableView.getFocusModel().focus(0);
tableView.getSelectionModel().select(0);
});
getChildren().addAll(add, tableView);
Building building = new Building();
building.setName("Building 100");
Function<Building, StringProperty> property = Building::nameProperty;
TableColumn<Building, String> column = new TableColumn<>("name");
column.setEditable(true);
column.setCellValueFactory(cellData -> property.apply(cellData.getValue()));
column.setCellFactory(p -> new EditingStringCell<>());
tableView.getColumns().add(column);
tableView.setItems(FXCollections.observableArrayList(building));
}
}
public static class EditingStringCell<S, T> extends TableCell<Building, String> {
static int id ;
private int myId;
private TextField textField;
public EditingStringCell() {
// just to see re-use of cells
myId = id++;
setContentDisplay(ContentDisplay.TEXT_ONLY);
// not needed, it's true by default
// setEditable(true);
}
@Override
protected void updateItem(String item, boolean empty) {
super.updateItem(item, empty);
setText(empty ? null : item);
}
@Override
public void startEdit() {
super.startEdit();
if (isEditing()) {
System.out.println("start edit " + getIndex() + " on id: " + myId);
updateEditControl(getItem());
}
}
private void updateEditControl(String item) {
if (textField == null) {
textField = new TextField();
// always use the highest abstract available
// so use action instead of keyEvent
textField.setOnAction(this::handleAction);
//textField.addEventHandler(KeyEvent.KEY_PRESSED,
// this::handleKeyPressed);
setGraphic(textField);
}
textField.setText(item == null ? "" : (item));
setContentDisplay(ContentDisplay.GRAPHIC_ONLY);
}
private void handleAction(ActionEvent ae) {
commitEdit(textField.getText());
}
//whenever pressing enter on a new "blank" row
//cancelEdit() gets called. But if you try again
//it works.
private void handleKeyPressed(KeyEvent e) {
if (e.getCode() == KeyCode.ENTER) {
commitEdit(textField.getText());
}
}
@Override
public void cancelEdit() {
super.cancelEdit();
System.out.println("cancel edit " + getIndex() + " on id: " + myId);
setContentDisplay(ContentDisplay.TEXT_ONLY);
}
@Override
public void commitEdit(String newValue) {
super.commitEdit(newValue);
System.out.println("commited: " + newValue + " index: " + getIndex() + " on id: " + myId);
setContentDisplay(ContentDisplay.TEXT_ONLY);
}
}
public class Building {
private final StringProperty name = new SimpleStringProperty();
public StringProperty nameProperty() {
return name;
}
public String getName() {
return name.get();
}
public void setName(String name) {
this.name.set(name);
}
}
public static void main(String[] args) {launch(args);}
}
关于java - 尝试提交 TableCell 时调用 cancelEdit(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46396423/
SQLite、Content provider 和 Shared Preference 之间的所有已知区别。 但我想知道什么时候需要根据情况使用 SQLite 或 Content Provider 或
警告:我正在使用一个我无法完全控制的后端,所以我正在努力解决 Backbone 中的一些注意事项,这些注意事项可能在其他地方更好地解决......不幸的是,我别无选择,只能在这里处理它们! 所以,我的
我一整天都在挣扎。我的预输入搜索表达式与远程 json 数据完美配合。但是当我尝试使用相同的 json 数据作为预取数据时,建议为空。点击第一个标志后,我收到预定义消息“无法找到任何内容...”,结果
我正在制作一个模拟 NHL 选秀彩票的程序,其中屏幕右侧应该有一个 JTextField,并且在左侧绘制弹跳的选秀球。我创建了一个名为 Ball 的类,它实现了 Runnable,并在我的主 Draf
这个问题已经有答案了: How can I calculate a time span in Java and format the output? (18 个回答) 已关闭 9 年前。 这是我的代码
我有一个 ASP.NET Web API 应用程序在我的本地 IIS 实例上运行。 Web 应用程序配置有 CORS。我调用的 Web API 方法类似于: [POST("/API/{foo}/{ba
我将用户输入的时间和日期作为: DatePicker dp = (DatePicker) findViewById(R.id.datePicker); TimePicker tp = (TimePic
放宽“邻居”的标准是否足够,或者是否有其他标准行动可以采取? 最佳答案 如果所有相邻解决方案都是 Tabu,则听起来您的 Tabu 列表的大小太长或您的释放策略太严格。一个好的 Tabu 列表长度是
我正在阅读来自 cppreference 的代码示例: #include #include #include #include template void print_queue(T& q)
我快疯了,我试图理解工具提示的行为,但没有成功。 1. 第一个问题是当我尝试通过插件(按钮 1)在点击事件中使用它时 -> 如果您转到 Fiddle,您会在“内容”内看到该函数' 每次点击都会调用该属
我在功能组件中有以下代码: const [ folder, setFolder ] = useState([]); const folderData = useContext(FolderContex
我在使用预签名网址和 AFNetworking 3.0 从 S3 获取图像时遇到问题。我可以使用 NSMutableURLRequest 和 NSURLSession 获取图像,但是当我使用 AFHT
我正在使用 Oracle ojdbc 12 和 Java 8 处理 Oracle UCP 管理器的问题。当 UCP 池启动失败时,我希望关闭它创建的连接。 当池初始化期间遇到 ORA-02391:超过
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 9 年前。 Improve
引用这个plunker: https://plnkr.co/edit/GWsbdDWVvBYNMqyxzlLY?p=preview 我在 styles.css 文件和 src/app.ts 文件中指定
为什么我的条形这么细?我尝试将宽度设置为 1,它们变得非常厚。我不知道还能尝试什么。默认厚度为 0.8,这是应该的样子吗? import matplotlib.pyplot as plt import
当我编写时,查询按预期执行: SELECT id, day2.count - day1.count AS diff FROM day1 NATURAL JOIN day2; 但我真正想要的是右连接。当
我有以下时间数据: 0 08/01/16 13:07:46,335437 1 18/02/16 08:40:40,565575 2 14/01/16 22:2
一些背景知识 -我的 NodeJS 服务器在端口 3001 上运行,我的 React 应用程序在端口 3000 上运行。我在 React 应用程序 package.json 中设置了一个代理来代理对端
我面临着一个愚蠢的问题。我试图在我的 Angular 应用程序中延迟加载我的图像,我已经尝试过这个2: 但是他们都设置了 src attr 而不是 data-src,我在这里遗漏了什么吗?保留 d
我是一名优秀的程序员,十分优秀!