跳至主要内容

MaskedTimeField

在 ChatGPT 中打开
阴影 dwc-timefield 24.10
Java API

MaskedTimeField 是一个文本输入组件,它允许用户输入 数字 作为时间,并在字段失去焦点时根据定义的掩码自动格式化输入。掩码指定了预期的时间格式,指导输入和显示。该组件支持灵活的解析、验证、本地化和值恢复,以实现一致的时间处理。

基础

寻找日期输入?

MaskedTimeField 专为 仅时间 输入而构建。如果您正在寻找一个能够处理 日期 并具有类似掩码格式的组件,请查看 MaskedDateField

您可以在没有参数或带参数的情况下实例化 MaskedTimeField。可以定义初始值、标签、占位符和用于值更改的事件监听器。

显示代码

掩码规则

MaskedTimeField 使用格式指示符定义时间的解析和显示方式。每个格式指示符以 % 开头,后跟表示时间组件的字母。

时间格式指示符

格式描述
%H小时 (24小时制)
%h小时 (12小时制)
%m分钟
%s
%pAM/PM

修饰符

修饰符精细化时间组件的显示:

修饰符描述
z零填充
s简短文本表示
l长文本表示
p紧凑数字
d十进制 (默认格式)

这些选项允许灵活且符合当地习惯的时间格式。

时间格式本地化

MaskedTimeField 通过设置适当的区域设置支持本地化。这确保了时间输入和输出匹配地区的惯例。

field.setLocale(Locale.GERMANY);

这会影响 AM/PM 指示符的显示、分隔符的处理和数值的解析方式。

解析逻辑

MaskedTimeField 根据定义的时间掩码解析用户输入。它接受完整和简写的数字输入,可以有或没有分隔符,从而允许灵活输入,同时确保时间有效。解析行为取决于掩码定义的格式顺序(例如,%Hz:%mz 代表小时/分钟)。该格式决定了数字序列的解释方式。

示例解析场景

输入掩码解释为
900%Hz:%mz09:00
1345%Hz:%mz13:45
0230%hz:%mz %p02:30 AM
1830%hz:%mz %p06:30 PM

设置最小/最大限制

您可以使用 setMin()setMax() 方法限制 MaskedTimeField 中允许的时间范围:

field.setMin(LocalTime.of(8, 0));
field.setMax(LocalTime.of(18, 0));

这两个方法接受类型为 java.time.LocalTime 的值。超出定义范围的输入被视为无效。

恢复值

MaskedTimeField 包括一个恢复功能,能够将字段的值重置为预定义的或原始的状态。这对于撤销更改或返回到默认时间非常有用。

field.setRestoreValue(LocalTime.of(12, 0));
field.restoreValue();

恢复值的方法

  • 通过编程,调用 restoreValue()
  • 通过键盘,按下 ESC(这是默认的恢复键,除非被事件监听器重写)
显示代码

验证模式

您可以使用正则表达式通过 setPattern() 方法应用客户端验证规则:

field.setPattern("^\\d{2}:\\d{2}$");

此模式确保只有匹配 HH:mm 格式(两个数字,冒号,两个数字)的值被认为是有效的。

正则表达式格式

模式必须遵循 JavaScript RegExp 语法,如 此处 所述。

输入处理注意事项

该字段尝试根据当前掩码解析和格式化数字时间输入。然而,用户仍然可以手动输入与预期格式不匹配的值。如果输入在语法上有效但在语义上不正确或无法解析(例如 99:99),则它可能通过模式检查,但在逻辑验证中失败。即使设置了正则表达式模式,您仍然应该在应用逻辑中验证输入值,以确保时间既格式正确又有意义。

时间选择器

MaskedTimeField 包括一个内置的时间选择器,允许用户通过视觉方式选择时间,而不是键入。这提高了对于技术水平较低的用户的可用性,或者在需要精确输入的情况下。

显示代码

访问选择器

您可以使用 getPicker() 访问时间选择器:

TimePicker picker = field.getPicker();

显示/隐藏选择器图标

使用 setIconVisible() 显示或隐藏字段旁的时钟图标:

picker.setIconVisible(true); // 显示图标

自动打开行为

您可以配置选择器在用户与字段交互时自动打开(例如点击、按 Enter 键或方向键):

picker.setAutoOpen(true);
通过选择器强制选择

为了确保用户只能通过选择器选择时间(而不能手动输入),请结合以下两个设置:

field.getPicker().setAutoOpen(true); // 在用户交互时打开选择器
field.setAllowCustomValue(false); // 禁用手动文本输入

此设置确保所有时间输入都通过选择器 UI,这在您想要严格控制格式并消除键入输入的解析问题时非常有用。

手动打开选择器

要通过编程打开时间选择器:

picker.open();

或使用别名:

picker.show(); // 与 open() 相同

设置选择器步长

您可以使用 setStep() 定义选择器中可选时间之间的间隔。这使您能够控制时间选项的粒度——非常适合在 15 分钟的时间块中调度等场景。

field.getPicker().setStep(Duration.ofMinutes(15));
步长约束

步长必须能整除一个小时或全天。否则,将抛出异常。

这确保下拉列表中包含可预测、均匀间隔的值,例如 09:0009:1509:30 等。

MaskedTimeFieldSpinner

MaskedTimeFieldSpinner 通过添加旋转控件扩展了 MaskedTimeField,使用户能够使用箭头键或 UI 按钮递增或递减时间。它提供了更引导式的交互方式,尤其适合于桌面应用程序。

显示代码

关键功能

  • 交互式时间步进:
    使用箭头键或旋转按钮递增或递减时间值。

  • 可自定义的旋转单位:
    通过 setSpinField() 选择要修改的时间部分:

    spinner.setSpinField(MaskedTimeFieldSpinner.SpinField.MINUTE);

    选项包括 HOURMINUTESECONDMILLISECOND

  • 最小/最大边界:
    继承了使用 setMin()setMax() 设置的最小和最大允许时间的支持。

  • 格式化输出:
    与来自 MaskedTimeField 的掩码和本地化设置完全兼容。

示例:按小时配置步进

MaskedTimeFieldSpinner spinner = new MaskedTimeFieldSpinner();
spinner.setSpinField(MaskedTimeFieldSpinner.SpinField.HOUR);

样式

Loading...