使用文本字段值更改监听器获取即时输入验证
为了对用户输入进行及时反馈,消息框必须显示为当用户修改文本字段中的文本时。然而,面对按 Enter 键后才触发消息框的问题,让我们深入研究代码并找到解决方案。
代码在文本字段上使用了 ActionListener,当有任何操作时都会调用该 ActionListener发生在字段上,包括按 Enter 键。此行为解释了使用 Enter 键后出现消息框的原因。为了解决这个问题,我们需要对文本字段值的变化做出更即时的响应。
解决方案在于为文本字段的底层 Document 添加监听器。为每个文本字段自动创建的文档表示文本内容。通过监视文档中的更改,我们可以响应文本中的任何更改,无论用户的输入方法如何。
这是更新的代码片段:
textField.getDocument().addDocumentListener(new DocumentListener() { public void changedUpdate(DocumentEvent e) { warn(); } public void removeUpdate(DocumentEvent e) { warn(); } public void insertUpdate(DocumentEvent e) { warn(); } public void warn() { if (Integer.parseInt(textField.getText())<=0){ JOptionPane.showMessageDialog(null, "Error: Please enter number bigger than 0", "Error Message", JOptionPane.ERROR_MESSAGE); } } });
此修改后的代码添加了文本字段的 DocumentListener,它对文档级别的更改做出反应。根据对文本的修改类型调用三种不同的 Update 方法(更改、删除、插入),从而有效地立即验证用户的输入。
以上是如何在不按 Enter 键的情况下立即在文本字段中进行输入验证?的详细内容。更多信息请关注PHP中文网其他相关文章!