开发者

A simple question regarding ActionListener and 'enter' key

开发者 https://www.devze.com 2023-02-23 14:19 出处:网络
I am working on an assignment, and I need to enter an SQL Query in a textfield.The user can either press the custom \'execute query\' button, or they can press the enter key. When either of these are

I am working on an assignment, and I need to enter an SQL Query in a textfield. The user can either press the custom 'execute query' button, or they can press the enter key. When either of these are used, it is to trigger an ActionListener (no other listener is allowed). Is it as simple as writing:

if (e.getSource()=='querybutton' || e.getSource=='enter')

Or is there more to it than this?

As I said, it is a simple question (I know).

edit:

I would write this bit in my ActionPerformed as:

       public void actionPerformed(ActionEvent e)
   {
      if(e.getSource()==gui.executeQueryButton || e.getSource()==gui.enter)
      {
         Strin开发者_运维知识库g query = gui.queryText.getText();

         //more code to follow  
      }
   }


e.getSource() actually returns the object responsible for firing the event (not the name of the variable you used when creating the control). In this case, your button. You could in principle compare e.getSource() with the actual button instances. However, are you actually adding this action listener to buttons other than those two? Presumably you'd only have to add this listener to the two buttons for which you want this behavior -- in which case you wouldn't have to have this if check.


" Is it as simple as writing:

if (e.getSource()=='querybutton' || e.getSource=='enter')"

It's not simple to write this, but rather it is wrong to write it.

For one you don't want to compare Strings with ==, for another, you don't declare Strings with single quotes, and for a third, the enter key is not obtained in this way, but rather by adding the appropriate ActionListener object to the JTextField itself, and finally there should be in a single ActionListener class that handles this action, so the if block is completely unnecessary. This can probably be best done with a small inner private ActionListener class. You'd then create one object of this class and add it as an ActionListener for the querybutton and for the JTextField.

edit 1:

A more complete example of what I mean is shown below, a demo class that has a private inner handler class:

import java.awt.event.*;
import javax.swing.*;

public class ActionListenerEg extends JPanel {
   private JButton queryButton = new JButton("Query");
   private JTextField textField = new JTextField("hello", 20);


   public ActionListenerEg() {
      QueryListener qListener = new QueryListener();
      queryButton.addActionListener(qListener);
      textField.addActionListener(qListener);

      add(queryButton);
      add(textField);
   }

   private class QueryListener implements ActionListener {
      public void actionPerformed(ActionEvent arg0) {
         String textInField = textField.getText();
         System.out.println("Use text in field, \"" + textInField + "\" to call SQL query in a background SwingWorker thread.");
      }
   }

   private static void createAndShowUI() {
      JFrame frame = new JFrame("ActionListenerEg");
      frame.getContentPane().add(new ActionListenerEg());
      frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
      frame.pack();
      frame.setLocationRelativeTo(null);
      frame.setVisible(true);
   }

   public static void main(String[] args) {
      java.awt.EventQueue.invokeLater(new Runnable() {
         public void run() {
            createAndShowUI();
         }
      });
   }
}

The ActionListener is fired either by pressing the button or by pressing enter from within the JTextField. I'd then have in my control class, code that is called inside of the actinoPerformed method.

edit 2: Having most handler or "control" code in its own Handler or Control class can be a good idea, but it doesn't have to implement ActionListener interface itself, but rather just have the code that will be called from within the ActionListener codes. For example, here I try to put all the handler code in its own class. It will have different methods that are called for various situations. e.g.,

import java.awt.Component;
import java.awt.event.*;

import javax.swing.*;

public class ActionListenerEg extends JPanel {
   private ActionListenerHandler handler;

   private JButton queryButton = new JButton("Query");
   private JButton displayButton = new JButton("Display");
   private JTextField textField = new JTextField("hello", 20);

   // pass in handler or handler
   public ActionListenerEg(final ActionListenerHandler handler) {
      this.handler = handler;
      QueryListener qListener = new QueryListener();
      queryButton.addActionListener(qListener);
      textField.addActionListener(qListener);
      displayButton.addActionListener(new ActionListener() {
         public void actionPerformed(ActionEvent e) {
            if (handler != null) {
               handler.displayActionPerformed(e);
            }
         }
      });

      add(queryButton);
      add(textField);
      add(displayButton);
   }

   private class QueryListener implements ActionListener {
      public void actionPerformed(ActionEvent e) {
         if (handler != null) {
            String textInField = textField.getText();
            handler.doQueryAction(e, textInField);
         }
      }
   }

   private static void createAndShowUI() {
      ActionListenerHandler handler = new ActionListenerHandler();
      JFrame frame = new JFrame("ActionListenerEg");
      frame.getContentPane().add(new ActionListenerEg(handler));
      frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
      frame.pack();
      frame.setLocationRelativeTo(null);
      frame.setVisible(true);
   }

   public static void main(String[] args) {
      java.awt.EventQueue.invokeLater(new Runnable() {
         public void run() {
            createAndShowUI();
         }
      });
   }
}

class ActionListenerHandler {

   public void displayActionPerformed(ActionEvent e) {
      JOptionPane.showMessageDialog((Component) e.getSource(), "Display things!");

   }

   public void doQueryAction(ActionEvent e, String textInField) {
      String text = "We will use \"" + textInField + "\" to help create and run the SQL Query";
      JOptionPane.showMessageDialog((Component) e.getSource(), text);   
   }

}

Please ask questions if it's clear as mudd, or if anything is wrong.

0

精彩评论

暂无评论...
验证码 换一张
取 消