JTable-doppelte Werte in Zeile
Das Füllen einer JTable mit einem benutzerdefinierten Datenmodell kann gelegentlich zum unerwarteten Auftreten doppelter Daten in den Tabellenzeilen führen . Auch wenn dies auf ein Problem mit dem DataModel hindeuten könnte, offenbart eine nähere Betrachtung oft etwas anderes, sodass die Ursache dieses Verhaltens ein Rätsel bleibt.
Eine mögliche Erklärung für dieses Phänomen liegt in der Implementierung der JTable selbst. Wenn ein DataModel zum Füllen einer JTable verwendet wird, werden die gerenderten Werte in der Tabelle direkt von der getValueAt-Methode des DataModel abgeleitet. Wenn diese Methode den eindeutigen Wert für jede Zelle in der Tabelle nicht korrekt abrufen kann, werden die gerenderten Werte über mehrere Zeilen hinweg dupliziert.
Um dieses Problem zu beheben, muss unbedingt sichergestellt werden, dass die getValueAt-Methode immer den zurückgibt Sollwert für jede Zelle. Dies kann erreicht werden, indem die zugrunde liegende Datenstruktur, die vom DataModel verwendet wird, ordnungsgemäß gefüllt wird. Im Fall des bereitgestellten DataModel füllt die Methode „populate“ die Daten-ArrayList mit Datenzeilen. Wenn jedoch der Code, der diese ArrayList auffüllt, jeder Zeile nicht korrekt eindeutige Werte zuweist, werden in der resultierenden Tabelle doppelte Werte angezeigt.
Zur Erinnerung: Es reicht nicht aus, nur die getValueAt-Methode zu ändern, um eindeutige Werte zurückzugeben Werte, da das zugrunde liegende Problem dadurch nicht behoben wird. Stattdessen sollte der Schwerpunkt darauf liegen, sicherzustellen, dass die Datenstruktur, die zum Auffüllen des Datenmodells verwendet wird, von Anfang an die richtigen Daten enthält. Durch die Adressierung der Datenquelle kann verhindert werden, dass doppelte Werte in der JTable angezeigt werden.
Um ein konkreteres Beispiel zu liefern, betrachten Sie den folgenden Codeausschnitt:
import java.util.ArrayList; import javax.swing.table.AbstractTableModel; public class CollectionDataModel extends AbstractTableModel { private ArrayList<ArrayList<String>> data; public CollectionDataModel() { data = new ArrayList<ArrayList<String>>(); } @Override public int getColumnCount() { if (data.isEmpty()) return 0; return data.get(0).size(); } @Override public int getRowCount() { return data.size(); } @Override public Object getValueAt(int rowIndex, int columnIndex) { if (rowIndex >= getRowCount()) return null; if (columnIndex >= getColumnCount()) return null; return data.get(rowIndex).get(columnIndex); } public void populate(Collection c) { data.clear(); for (Item i : c.getItems()) { ArrayList<String> row = new ArrayList<String>(); for (Property p : i.getProperties().values()) { row.add(p.toString()); } data.add(row); } fireTableDataChanged(); } }
In diesem Code , füllt die Methode „populate“ die Daten-ArrayList mit Datenzeilen, die vom Collection-Objekt abgerufen wurden. Um doppelte Werte in der JTable zu vermeiden, muss unbedingt sichergestellt werden, dass jede Zeile in der ArrayList eindeutige Daten enthält. Dies kann erreicht werden, indem vor dem Hinzufügen neuer Zeilen zur ArrayList überprüft wird, ob doppelte Daten vorhanden sind, oder indem eine Datenstruktur verwendet wird, die Eindeutigkeit erzwingt.
Durch die direkte Adressierung der Datenquelle ist es möglich, doppelte Werte zu verhindern erscheint in der JTable. Dieser Ansatz ist zuverlässiger und effizienter als die Manipulation der getValueAt-Methode, da er sicherstellt, dass die zugrunde liegenden Daten von Anfang an korrekt sind.
Das obige ist der detaillierte Inhalt vonWarum zeigen meine JTable-Zeilen doppelte Werte an, wenn ich ein benutzerdefiniertes Datenmodell verwende?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!