java - 如何从 ArrayList 填充 JComboBox
问题描述
我正在尝试从 MySQL 数据库中获取一些值以JComboBox
使用ArrayList
并DefaultComboBoxModel
避免获取重复值。因为当我调用该方法来获取值时,JComboBox 会一次又一次地向 JComboBox 填充相同的值。
目前,当下面的代码运行组合框显示像这样的值,
sometext@24084, sometext@716a1
这是我的代码,
public static void loadAll(JComboBox comboBox) {
try {
ArrayList<Combo> comboList = ComboBoxController.getComboType();
DefaultComboBoxModel dtm = (DefaultComboBoxModel)comboBox.getModel();
for (Combo combo : comboList) {
Object[] rowData = {combo.getComboType()};
dtm.addElement(rowData);
}
} catch (SQLException | ClassNotFoundException ex)
{
Logger.getLogger(AllComboBoxMethod.class.getName()).log(Level.SEVERE, null, ex);
}
}
和获取方法,
int itemCount = combo.getItemCount();
for(int i = 1; i < itemCount; i++) {
combo.removeItemAt(0);
}
String sql = "SELECT * FROM combo_type";
dbConnection = DbConnection.getInstance();
con = dbConnection.getConnection();
stm = con.createStatement();
rst = stm.executeQuery(sql);
ArrayList<Combo> comboList = new ArrayList();
while(rst.next()) {
comboList.add(new Combo(rst.getString(2)));
}
return comboList;
那么我做错了什么?这是避免获取重复值的唯一方法吗?我之前尝试comboBox.removeAllItems()
过(在添加此代码之前),然后获取值。但它给了我NullPointerException
一些时间。那么我该如何解决这个问题呢?
解决方案
这
sometext@716a1
是具体类实例的唯一标识符/内存地址。
你看到了,因为你没有正确地覆盖
public String toString();
方法,用于Combo
类。
此外,DefaultComboBoxModel
是一个通用的启用类
DefaultComboBoxModel<E>
那么为什么要使用原始实例?
你应该处理
DefaultComboBoxModel<Combo>
反而。这意味着你可以做
for (final Combo combo : comboList) {
dtm.addElement(combo);
}
尝试
public static void loadAll(final JComboBox comboBox) {
try {
final List<Combo> comboList = ComboBoxController.getComboType();
final DefaultComboBoxModel dtm = (DefaultComboBoxModel) comboBox.getModel();
dtm.removeAllItems();
for (final Combo combo : comboList) {
dtm.addElement(combo.getComboType());
}
} catch (final SQLException | ClassNotFoundException ex) {
Logger.getLogger(AllComboBoxMethod.class.getName()).log(Level.SEVERE, null, ex);
}
}
int itemCount = combo.getItemCount();
for (int i = itemCount - 1; i >= 0; i++) {
combo.removeItemAt(0);
}
推荐阅读
- ruby-on-rails - 这个表的索引在哪里
- javascript - iOS Web 应用程序在切换到银行 ID 时失去连接
- python - Python关闭证书验证
- python - 如何从字典中打印出格式良好的表格
- java - Android Studio - PagerView2(With Fragment) power 2
- android - 如何正确提取手机游戏文件?
- anglesharp - AngleSharp OpenAsync 返回令人困惑的错误?没有网络的时候
- sql-server - 使用 Azure Active Directory 连接到 MSSQL 服务器的 JDBC
- java - 如何在 java 中将 SSL 客户端证书与 jersey 客户端一起使用
- botium-box - Botium:- 使用 botium 和 webdriverIO 进行聊天机器人测试