日期时间验证器

对字符串值(格式化为 JSF 日期/时间值)或者 JavaScript™ 日期对象进行测试,以确定其是否符合一组 JSF 验证约束。

DateTimeValidator 用于测试某个值是否符合一组验证约束。您可以将 JavaScript 日期对象传递给此验证器,也可以将已使用所提供的 DateTimeConverter 转换为日期对象的字符串传递给此验证器,如果转换失败,则值无效。

可以在构造验证器时提供验证约束,也可以使用 GetAttribute/SetAttribute 调用来添加/除去验证约束。可以提供任意数目的约束。不提供约束是没有意义的。

如果提供了 required 约束并设置为 true,则验证器将要求值不为空(如果提供了日期对象)或者值不是空字符串(如果提供了字符串)。如果未设置 required,则会将空值/空字符串视为有效值,而不考虑任何其他约束。即,如果未设置 required,则空值始终是有效值。

如果指定了 minimum-bound 作为约束,则值(如果不为空)必须大于或等于所指定的界限。如果指定了 maximum-bound 作为约束,则值必须小于或等于最大值界限。

可以使用 JavaScript EL 表达式来测试某个值是否在集合内以及测试某个值是否在不连续的范围内,等等。目前,不能使用此表达式将一个值与页面上的另一个值进行比较。

将按以下顺序对约束进行测试,尽管这对验证结果并无影响:
  • required
  • minimum-bound
  • maximum-bound
  • constraint-expression

JavaScript 构造函数

hX_5.addValidator("id", new hX_5.DateTimeValidator(attributes)); 其中

id

组件所连接至的 HTML 标记的 ID。

属性

表 1. 日期时间验证器属性

属性名称

描述

required

如果是必需的,则该值可能不能为 NULL 或空字符串。如果不是必需的,则该值可以为 NULL 或空字符串,并跳过其他验证约束。

minimum-bound

允许的最小值。范围应格式化为 yyyyMMddHHmmssSSS,其中结尾组件可能会被忽略。

maximum-bound

允许的最大值。范围应格式化为 yyyyMMddHHmmssSSS,其中结尾组件可能会被忽略。

constraint-expression

必须满足的 JavaScript EL 表达式。JavaScript EL 表达式与 JSF EL 表达式相同,但以下各方面除外:
  • 不能使用“字符串”格式来表示运算符,例如,use == not .eq.。
  • 可以引用的唯一值是 @testValue,它表示要进行测试的值。
  • 可通过使用 Java™ 访问者来访问 @testValue 中的日期/时间组件。具体地说,可以使用 .date、.day、.hours、.minutes、.month、.seconds、.timezoneOffset、.time 和 .year。

API 调用

表 2. 日期时间验证器 API 调用

API 调用

描述

boolean = validate(value, converter)

验证值(字符串或日期对象)。需要转换器对象或转换器的 ID。如果值通过验证,则返回 true。如果值失败,则返回 false,并设置 lastError。

string = lastError()

如果转换失败,则将失败原因作为本地化字符串返回。

object = setAttribute(attribute)

设置属性,或如果以前已设置属性,则更改其值。

string = getAttribute(attribute-name)

检索属性的当前值。

局限性

对于日期时间转换器而言,可以验证的有效日期范围是 1582 年 10 月 15 日到 9999 年 12 月 31 日。

示例代码

验证输入字段的值。

// Construct a converter with a pattern of MMMM dd, yyyy
hX.addConverter("AZ", new hX.DateTimeConverter("format:MMMM dd, yyyy", "strict:2",
                  "base-2digit-span:30"));

// Construct a validator that checks that a field is present and the date is the 1st or the 15th of the month
hX.addValidator("1Z", new hX.DateTimeValidator("required:true",
                  "constraint-expression:(@testValue.day == 1 || @testValue.day == 15"));

// Validate a value
var x = document.getElementById("form1:textA");
var v = hX.getValidatorById("1Z");
if (!v.validate(x.value, "AZ")) alert ("ERROR: " + v.lastError());

反馈