- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我的数据源提供了一个 ObservableList
,但是对于我的 ListView,我需要一个 ObservableList
.
MỘT Warning
基本上只是字符串的装饰器,添加一个 boolean 值以提供一种方法来跟踪我的 ListView 的复选框状态,如 cái này 中所建议的那样回答。
class Warning {
private final ReadOnlyStringWrapper name;
private final BooleanProperty checked;
/* ... */
}
目前我正在观察原始列表中的更改事件并手动添加/删除警告列表中的项目:
ObservableList stringList = ...;
ObservableList warningList = ...;
stringList.addListener(new ListChangeListener() {
@Ghi đè
public void onChanged(ListChangeListener.Change extends String> change) {
if (change.wasAdded()) {
warningList.addAll(change.getAddedSubList().stream().map(Warning::new).collect(Collectors.toList()));
} else if (change.wasRemoved()) {
change.getRemoved().forEach(str -> {
warningList.removeIf(w -> str.equals(w.name));
});
}
}
});
Câu hỏi của tôi là:是否有更优雅的方式来修饰我的字符串类型列表,以便它可以用作警告类型列表而无需手动传递更改事件?
更准确地说:如果将字符串添加到原始列表或从原始列表中删除,我希望立即在警告列表和 ListView 中看到此更改。
câu trả lời hay nhất
自从您发布后,我一直在思考这个问题。按照我在评论中建议的那样使用 EasyBind 是行不通的,因为每次您在映射列表上调用 get(...)
时它都会创建一个新的 Warning
. Vì thế
stringList.add("foo");
warningList.get(0).setChecked(true);
assert warningList.get(0).isChecked();
会失败。
此外,如果您在源列表 (stringList
) 中有重复的条目,您的机制就会出错(我认为),因为您会从 warningList
中删除所有相应的条目当从 stringList
中删除单个元素时。事实上,正确获取删除的元素非常棘手。
这是一个基于 Tomas Mikula 的 MappedList
的解决方案它缓存源元素和映射元素之间的映射。它使用 IdentityHashMap
来确保重复元素在两个列表中的行为正确。请注意,这仅适用于您希望在将项目添加到源列表时创建新对象的特定情况,因此它不打算(也不会工作)替代 EasyBind 中的机制。
nhập java.util.ArrayList;
import java.util.IdentityHashMap;
nhập java.util.List;
import java.util.function.Function;
import javafx.application.Application;
import javafx.beans.property.BooleanProperty;
import javafx.beans.property.ReadOnlyStringProperty;
import javafx.beans.property.ReadOnlyStringWrapper;
import javafx.beans.property.SimpleBooleanProperty;
import javafx.collections.FXCollections;
import javafx.collections.ListChangeListener.Change;
import javafx.collections.ObservableList;
import javafx.collections.transformation.TransformationList;
import javafx.geometry.Insets;
import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.control.ListView;
import javafx.scene.control.TextField;
import javafx.scene.control.cell.CheckBoxListCell;
import javafx.scene.layout.HBox;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;
public class WrappedObjectListExample extends Application {
@Ghi đè
public void start(Stage primaryStage) {
ObservableList stringList = FXCollections.observableArrayList("One", "Two", "Three");
ObservableList warningList = new CachingMappedList(stringList, Warning::new);
ListView stringListView = new ListView<>(stringList);
ListView warningListView = new ListView<>(warningList);
warningListView.setCellFactory(CheckBoxListCell.forListView(Warning::checkedProperty));
TextField textField = new TextField();
textField.setOnAction(e -> {
if (! textField.getText().isEmpty()) {
stringList.add(textField.getText());
textField.setText("");
}
});
Button remove = new Button("Remove");
remove.setOnAction(e -> stringList.remove(stringListView.getSelectionModel().getSelectedIndex()));
remove.disableProperty().bind(stringListView.getSelectionModel().selectedItemProperty().isNull());
HBox lists = new HBox(10, stringListView, warningListView);
VBox root = new VBox(10, lists, textField, remove);
root.setPadding(new Insets(20));
primaryStage.setScene(new Scene(root));
primaryStage.show();
}
public static class Warning {
private final ReadOnlyStringWrapper name = new ReadOnlyStringWrapper();
private final BooleanProperty checked = new SimpleBooleanProperty();
public Warning(String name) {
this.name.set(name);
}
public final ReadOnlyStringProperty nameProperty() {
return this.name.getReadOnlyProperty();
}
public final String getName() {
return this.nameProperty().get();
}
public final BooleanProperty checkedProperty() {
return this.checked;
}
public final boolean isChecked() {
return this.checkedProperty().get();
}
public final void setChecked(final boolean checked) {
this.checkedProperty().set(checked);
}
@Ghi đè
công khai String toString() {
return getName();
}
}
public static class CachingMappedList extends TransformationList {
private final Function mapper ;
private final IdentityHashMap cache ;
public CachingMappedList(ObservableList source, Function mapper) {
super(source);
this.mapper = mapper ;
this.cache = new IdentityHashMap<>();
}
@Ghi đè
protected void sourceChanged(Change extends T> c) {
fireChange(new Change(this) {
@Ghi đè
public boolean wasAdded() {
return c.wasAdded();
}
@Ghi đè
public boolean wasRemoved() {
return c.wasRemoved();
}
@Ghi đè
public boolean wasReplaced() {
return c.wasReplaced();
}
@Ghi đè
public boolean wasUpdated() {
return c.wasUpdated();
}
@Ghi đè
public boolean wasPermutated() {
return c.wasPermutated();
}
@Ghi đè
public boolean next() {
return c.next();
}
@Ghi đè
công khai void reset() {
c.reset();
}
@Ghi đè
public int getFrom() {
return c.getFrom();
}
@Ghi đè
public int getTo() {
return c.getTo();
}
@Ghi đè
public List getRemoved() {
List removed = new ArrayList<>();
c.getRemoved().forEach(t -> removed.add(cache.get(t)));
return removed;
}
@Ghi đè
public int getPermutation(int i) {
return c.getPermutation(i);
}
@Ghi đè
protected int[] getPermutation() {
throw new AssertionError("Unreachable code");
}
});
// clean up cache:
c.reset();
while (c.next()) {
if (c.wasRemoved()) {
c.getRemoved().forEach(cache::remove);
}
}
}
@Ghi đè
public int getSourceIndex(int index) {
return index ;
}
@Ghi đè
public S get(int index) {
return cache.computeIfAbsent(getSource().get(index), mapper);
}
@Ghi đè
public int size() {
return getSource().size();
}
}
public static void main(String[] args) {
khởi chạy(đối số);
}
}
关于java - 装饰 ObservableList 并保留更改事件的最佳实践,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31230312/
我正在尝试将 WPF CodeBehid 事件(如 Event、Handler、EventSetter)转换为 MVVM 模式。我不允许使用 System.Windows.Controls,因为我使用
我可能误解了 Backbone 中的事件系统,但是当我尝试以下代码时什么也没有发生。当我向 Backbone.Events 扩展对象添加新属性时,它不应该触发某种更改、更新或重置事件吗?就像模型一样吗
我遇到了一个简单的问题,就是无法弄清楚为什么它不起作用。我有一个子组件“app-buttons”,其中我有一个输入字段,我想听,所以我可以根据输入值过滤列表。 如果我将输入放在我有列表的根组件中,一切
System.Timers.Timer 的 Elapsed 事件实际上与 System.Windows.Forms.Timer 的 Tick 事件相同吗? 在特定情况下使用其中一种比使用另一种有优势吗
嗨,这个 javascript 代码段是什么意思。(evt) 部分是如此令人困惑.. evt 不是 bool 值。这个怎么运作? function checkIt(evt) { evt
我正在使用jquery full calendar我试图在事件被删除时保存它。 $('calendar').fullCalendar ({
我有两个链接的鼠标事件: $('body > form').on("mousedown", function(e){ //Do stuff }).on("mouseup", function(
这是我的代码: $( '#Example' ).on( "keypress", function( keyEvent ) { if ( keyEvent.which != 44 ) {
我尝试了 dragOver 事件处理程序,但它没有正常工作。 我正在研究钢琴,我希望能够弹奏音符,即使那个键上没有发生鼠标按下。 是否有事件处理程序? 下面是我正在制作的钢琴的图片。 最佳答案 您应该
当悬停在相邻文本上时,我需要使隐藏按钮可见。这是通过 onMouseEnter 和 onMouseLeave 事件完成的。但是当点击另外的文本时,我需要使按钮完全可见并停止 onMouseLeave
我有ul标签内 div标签。我申请了mouseup事件 div标记和 click事件 ul标签。 问题 每当我点击 ul标签,然后都是 mouseup和 click事件被触发。 我想要的是当我点击 u
我是 Javascript 和 jQuery 的新手,所以我有一个非常愚蠢的疑问,请耐心等待 $(document).click(function () { alert("!"); v
我有一个邮政编码解析器,我正在使用 keyup 事件处理程序来跟踪输入长度何时达到 5,然后查询服务器以解析邮政编码。但是我想防止脚本被不必要地调用,所以我想知道是否有一种方法可以跟踪 keydown
使用事件 API,我有以下代码来发布带有事件照片的事件 $facebook = new Facebook(array( "appId" => "XXX", "se
首次加载 Microsoft Word 时,既不会触发 NewDocument 事件也不会触发 DocumentOpen 事件。当 Word 实例已打开并打开新文档或现有文档时,这些事件会正常触发。
我发现了很多相关问题(这里和其他地方),但还没有具体找到这个问题。 我正在尝试监听箭头键 (37-40) 的按键事件,但是当以特定顺序使用箭头键时,后续箭头不会生成“按键”事件。 例子: http:/
给定的 HTML: 和 JavaScript 的: var $test = $('#test'); $test.on('keydown', function(event) { if (eve
我是 Node.js 的新手,希望使用流运行程序。对于其他程序,我必须同时启动一个服务器(mongodb、redis 等),但我不知道我是否应该用这个运行一个服务器。请让我知道我哪里出了问题以及如何纠
我正在尝试使用 Swift 和 Cocoa 创建一个适用于 OS X 的应用程序。我希望应用程序能够响应关键事件,而不将焦点放在文本字段上/文本字段中。我在 Xcode 中创建了一个带有 Storyb
我有以下代码: (function(w,d,s,l,i){ w[l]=w[l]||[];w[l].push({
Tôi là một lập trình viên xuất sắc, rất giỏi!