这是代码,任何人都可以轻松快速地运行,这显示了我的问题:
import java.awt.Color;
import java.awt.Component;
import java.awt.EventQueue;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.border.EmptyBorder;
import javax.swing.DefaultListCellRenderer;
import javax.swing.DefaultListModel;
import javax.swing.DefaultListSelectionModel;
import javax.swing.JScrollPane;
import javax.swing.JList;
import javax.swing.JButton;
import javax.swing.ListSelectionModel;
import java.awt.event.ActionListener;
import java.awt.event.ActionEvent;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import java.util.ArrayList;
public class Driver extends JFrame {
public ArrayList<String> RN = new ArrayList<String>();
private JPanel contentPane;
public static void main(String[] args) {
EventQueue.invokeLater(new Runnable() {
public void run() {
try {
Driver frame = new Driver();
frame.setVisible(true);
} catch (Exception e) {
e.printStackTrace();
}
}
});
}
public Driver() {
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
setBounds(100, 100, 605, 497);
contentPane = new JPanel();
contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
setContentPane(contentPane);
contentPane.setLayout(null);
DefaultListSelectionModel m = new DefaultListSelectionModel();
m.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
m.setLeadAnchorNotificationEnabled(false);
JScrollPane scrollPane = new JScrollPane();
scrollPane.setBounds(26, 133, 538, 133);
contentPane.add(scrollPane);
scrollPane.setViewportView(listRN);
listRN.setSelectionModel(m);
// listRN.setCellRenderer(new MyListCellRenderer());
listRN.addMouseListener(mouseListener);
JScrollPane scrollPane_1 = new JScrollPane();
scrollPane_1.setBounds(26, 296, 538, 133);
contentPane.add(scrollPane_1);
scrollPane_1.setViewportView(listPL);
listPL.setSelectionModel(m);
// listPL.setCellRenderer(new MyListCellRenderer());
JButton btnNewButton = new JButton("Load");
btnNewButton.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent arg0) {
RN.add("Ivan");
RN.add("Gaga");
RN.add("Dragan");
for(int i=0;i<RN.size();i++){
modelRN.addElement(RN.get(i));
}
}
});
btnNewButton.setBounds(386, 58, 89, 23);
contentPane.add(btnNewButton);
}
MouseListener mouseListener = new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
String d = null;
if (e.getClickCount() == 1) {
int index = listRN.locationToIndex(e.getPoint());
System.out.println("clicked on Item " + index);
d = listRN.getSelectedValue();
modelPL.addElement(d);
}
}
};
DefaultListModel<String> modelRN = new DefaultListModel<String>();
DefaultListModel<String> modelPL = new DefaultListModel<String>();
JList<String> listRN = new JList<String>(modelRN);
JList<String> listPL = new JList<String>(modelPL);
}
这是一个简单的例子。单击“加载”按钮,将字符串添加到第一个JList。单击该JList中的字符串并将其加载到第二个JList,因此没有什么重要的。我的问题是在那之后JLists的行为......当我点击Jlist中的一个选项时,它将字符串加载到第二个Jlist但突出显示的选项跳转到另一个String ...加上当我点击一个字符串时在第二个Jlist中,它连接到第一个.Jlist。
理解JList行为的根本缺陷是什么?
答案 0 :(得分:2)
listPL和listRN不应该具有相同的ListSelectionModel,当您在第一个列表中选择一个项目时,它会添加到第二个列表中,并且其中的所选项目也会更改,因此第一个列表中的所选项目也会更改,因为它们具有相同的ListSelectionModel。