首页 > 解决方案 > 如何从 ArrayList 填充 JComboBox

问题描述

我正在尝试从 MySQL 数据库中获取一些值以JComboBox使用ArrayListDefaultComboBoxModel避免获取重复值。因为当我调用该方法来获取值时,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一些时间。那么我该如何解决这个问题呢?

标签: javaswingarraylistjcombobox

解决方案


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); 
}

推荐阅读