MaskedDateField
MaskedDateField 是一个文本输入组件,让用户可以以数字形式输入日期,并在字段失去焦点时根据定义的掩码自动格式化输入。掩码指定了预期的日期格式,为输入和显示提供指导。该组件支持灵活的解析、验证、本地化和数值恢复,以实现一致的、特定于区域的日期处理。
基础
MaskedDateField 仅专注于日期值。如果您需要类似的组件来输入和格式化时间,请查看 MaskedTimeField。
MaskedDateField 可以在有或没有参数的情况下实例化。您可以定义初始值、标签、占位符以及一个值变化的事件监听器。
显示代码
- Java
掩码规则
MaskedDateField 支持全球多种日期格式,这些格式因日、月和年的顺序而异。常见的模式包括:
- 日/月/年(在欧洲大部分地区使用)
- 月/日/年(在美国使用)
- 年/月/日(在中国、日本和韩国使用;也是ISO标准:
YYYY-MM-DD)
在这些格式中,本地变体包括分隔符的选择(例如 -, /, 或 .)、年份是否为两位数或四位数,以及单数字月份或日期是否用前导零填充。
为处理这种多样性,MaskedDateField 使用格式指示符,每个指示符以 % 开头,后跟代表日期特定部分的字母。这些指示符定义输入如何被解析以及日期如何显示。
日期格式指示符
| 格式 | 描述 |
|---|---|
%Y | 年 |
%M | 月 |
%D | 日 |
修饰符
修饰符允许更好地控制日期组成部分的格式:
| 修饰符 | 描述 |
|---|---|
z | 零填 |
s | 短文本表示 |
l | 长文本表示 |
p | 打包数字 |
d | 小数(默认格式) |
这些可以组合以构建多种日期掩码。
日期格式本地化
MaskedDateField 通过设置适当的语言环境来适应区域日期格式。这确保日期以符合用户预期的方式显示和解析。
| 区域 | 格式 | 示例 |
|---|---|---|
| 美国 | MM/DD/YYYY | 07/04/2023 |
| 欧洲 | DD/MM/YYYY | 04/07/2023 |
| ISO标准 | YYYY-MM-DD | 2023-07-04 |
要应用本地化,请使用 setLocale() 方法。该方法接受一个 java.util.Locale,并自动调整格式和解析:
dateField.setLocale(Locale.FRANCE);
解析逻辑
MaskedDateField 根据定义的日期掩码解析用户输入。它接受完整和缩略的数字输入,带有或不带分隔符,这允许灵活输入,同时确保日期有效。
解析行为取决于掩码定义的格式顺序(例如 %Mz/%Dz/%Yz 表示月/日/年)。此格式确定数字序列如何被解释。
例如,假设今天是 2012年9月15日,以下是如何解释各种输入的:
示例解析场景
| 输入 | YMD (ISO) | MDY (US) | DMY (EU) |
|---|---|---|---|
1 | 单个数字始终被解释为当月的日期,因此这将是2012年9月1日。 | 同YMD | 同YMD |
12 | 两个数字总是被解释为当月的日期,因此这将是2012年9月12日。 | 同YMD | 同YMD |
112 | 三个数字被解释为一个数字的月份后跟两个数字的日期,因此这将是2012年1月12日。 | 同YMD | 三个数字被解释为一个数字的日期后跟两个数字的月份,因此这将是2012年12月1日。 |
1004 | 四个数字被解释为MMDD,因此这将是2012年10月4日。 | 同YMD | 四个数字被解释为DDMM,因此这将是2012年4月10日。 |
020304 | 六个数字被解释为YYMMDD,因此这将是2002年3月4日。 | 六个数字被解释为MMDDYY,因此这将是2004年2月3日。 | 六个数字被解释为DDMMYY,因此这将是2004年3月2日。 |
8 digits | 八个数字被解释为YYYYMMDD。例如,20040612 是2004年6月12日。 | 八个数字被解释为MMDDYYYY。例如,06122004 是2004年6月12日。 | 八个数字被解释为DDMMYYYY。例如,06122004 是2004年12月6日。 |
12/6 | 两个用有效分隔符分隔的数字被解释为MM/DD,因此这将是2012年12月6日。 注意:所有字符(字母和数字除外)都被视为有效分隔符。 | 同YMD | 两个用分隔符分隔的数字被解释为DD/MM,因此这将是2012年6月12日。 |
3/4/5 | 2012年4月5日 | 2005年3月4日 | 2005年4月3日 |
文本日期解析 25.11
默认情况下,MaskedDateField 仅接受数字输入日期。然而,您可以启用文本日期解析来允许用户在输入中输入月份和日期名称。这个功能特别适合于创建更自然的日期输入。
要启用文本解析,请使用 setTextualDateParsing() 方法:
dateField.setTextualDateParsing(true);
月份名称替代
启用文本解析后,您可以在掩码中使用特殊修饰符来接受月份名称而不是数字值:
%Ms- 接受短月份名称(Jan, Feb, Mar, 等等)%Ml- 接受长月份名称(January, February, March, 等等)
月份名称可以出现在掩码的任何位置,且字段仍然可以接受 数字输入作为后备。
示例
| 掩码 | 输入 | 结果 |
|---|---|---|
%Ms/%Dz/%Yz | Sep/01/25 | 有效 - 解析为2025年9月1日 |
%Ml/%Dz/%Yz | September/01/25 | 有效 - 解析为2025年9月1日 |
%Dz/%Ml/%Yz | 01/September/25 | 有效 - 解析为2025年9月1日 |
%Mz/%Dz/%Yz | 09/01/25 | 有效 - 数字后备仍然有效 |
所有12个月都是以短(Jan, Feb, Mar, Apr, May, Jun, Jul, Aug, Sep, Oct, Nov, Dec)和长(January, February, 等等)形式支持的。
星期名称装饰
可以在输入中包含星期名称以提高可读性,但它们是装饰性的,在解析时会被去除。它们不会影响实际的日期值。
%Ds- 接受短的星期名称(Mon, Tue, Wed, 等等)%Dl- 接受长的星期名称(Monday, Tuesday, Wednesday, 等等)
使用星期名称(%Ds 或 %Dl)时,您的掩码必须也包含 %Dz 或 %Dd 来指定实际的日期数字。没有数字日期组件,输入将被视为无效。
示例
| 掩码 | 输入 | 结果 |
|---|---|---|
%Ds %Mz/%Dz/%Yz | Mon 09/01/25 | 有效 - 星期名称是装饰性的 |
%Dl %Mz/%Dz/%Yz | Monday 09/01/25 | 有效 - 星期名称是装饰性的 |
%Mz/%Dz/%Yz %Ds | 09/01/25 Tue | 有效 - 星期名称在最后 |
%Dl/%Mz/%Yz | Monday/09/25 | 无效 - 缺少 %Dz |
%Mz/%Dl/%Yz | 09/Monday/25 | 无效 - 缺少 %Dz |
所有7个星期几都以短(Mon, Tue, Wed, Thu, Fri, Sat, Sun)和长(Monday, Tuesday, 等等)形式支持。