如何获取日期字符串模型属性的客户端验证
本文关键字:客户端 验证 属性 模型 何获 取日期 字符串 | 更新日期: 2023-09-27 18:36:03
在我的模型中,我有一个包含日期属性的对象。(使用字符串是因为这是前一个程序员写的):
[Display(Name = "Payment Date")]
[Date(ErrorMessage = "Please enter a valid date")]
public string PaymentDate { get; set; }
以下是PaymentDate
使用的自定义日期属性:
public sealed class DateAttribute : ValidationAttribute, IClientValidatable
{
public override bool IsValid(object value)
{
var dateString = value as string;
if (string.IsNullOrWhiteSpace(dateString))
{
return false;
}
DateTime result;
var success = DateTime.TryParse(dateString, out result);
return success;
}
public IEnumerable<ModelClientValidationRule> GetClientValidationRules(ModelMetadata metadata, ControllerContext context)
{
return new ModelClientValidationRule[] { new ModelClientValidationRule
{
ValidationType = "paymentdate",
ErrorMessage = this.ErrorMessage }
};
}
}
这在服务器端效果很好,但在客户端则不然。在视图中,我尝试创建一个自定义函数来进行验证,但它似乎无法正常工作。前面的点导致语法错误test
// custom jquery validation method
jQuery.validator.addMethod('validDate', function (value, element, params) {
return Invalid|NaN/.test(new Date(value));
}, '');
// unobtrusive adapter
jQuery.validator.unobtrusive.adapters.add('paymentdate', {}, function (options) {
options.rules['validDate'] = true;
options.messages['validDate'] = options.message;
});
如何使用我已经工作的服务器端验证进行客户端验证?
注意:我使用的是自定义属性,因为稍后会添加一些自定义验证。
抛出语法错误是因为正则表达式无效,开头需要一个/
/Invalid|NaN/.test(...)
但是,我要指出几件事。
- 建议在分析日期字符串时使用 Date.parse
- 检查
NaN
时最好使用 isNaN 函数
这是您的验证器的修订版本
jQuery.validator.addMethod('validDate', function (value, element, params) {
return !isNaN(Date.parse(value));
}, '');
jQuery.validator.addMehod('validDate', function (value, element, params) {
return Invalid|NaN/.test(new Date(value));
}, '');
跟
jQuery.validator.addMethod('validDate', function (value, element, params) {
return Invalid|NaN/.test(new Date(value));
}, '');
看起来函数中缺少一个 t。