[英]CustomValidator to validate multiple date formats
我在Asp.net Webform中使用CustomValidator字段來驗證日期字段。 如何驗證多種日期格式? 例如,這將是有效的:01/05/2019並且這將是有效的:1/05/2019並且這將是有效的:2019/05/01。 這是后面的代碼,當嘗試驗證所有三種日期類型時不起作用,但僅使用一種日期格式時才起作用:
protected void CustomValidator1_ServerValidate(object source, ServerValidateEventArgs args)
{
//Issue Date
if (Regex.IsMatch(txtIssueDate.Text, "(((0|1)[0-9]|2[0-9]|3[0-1])\\/(0[1-9]|1[0-2])\\/((19|20)\\d\\d))$"))
{
DateTime dt;
args.IsValid = DateTime.TryParseExact(args.Value, "dd/MM/yyyy", new CultureInfo("en-GB"), DateTimeStyles.None, out dt);
args.IsValid = DateTime.TryParseExact(args.Value, "d/MM/yyyy", new CultureInfo("en-GB"), DateTimeStyles.None, out dt);
args.IsValid = DateTime.TryParseExact(args.Value, "yyyy/MM/dd", new CultureInfo("en-GB"), DateTimeStyles.None, out dt);
if (args.IsValid)
{
args.IsValid = true;
}
}
else
{
args.IsValid = false;
ScriptManager.RegisterStartupScript(UpdatePanel2, UpdatePanel2.GetType(), "myFunction", "alertInvalidDate();", true);
}
}
編輯我接受了薩赫(Sach)的建議,並使用此方法檢查日期字段-完全忘記了自定義驗證器:
var formats = new string[] { "dd/MM/yyyy", "d/MM/yyyy", "yyyy/MM/dd" };
var isValidFormat = DateTime.TryParseExact(txtIssueDate.Text, formats, CultureInfo.CurrentCulture, DateTimeStyles.None, out DateTime res1);
if (isValidFormat)
{
//It's all good.
}
else
{
ScriptManager.RegisterStartupScript(UpdatePanel2, UpdatePanel2.GetType(), "myFunction", "alertInvalidDate();", true);
}
您只想將TryParseExact()
與多種格式一起使用。
static void Main()
{
var formats = new string[] { "dd/MM/yyyy", "d/MM/yyyy", "yyyy/MM/dd" };
DateTime.TryParseExact("01/05/2019", formats, CultureInfo.CurrentCulture, DateTimeStyles.None, out DateTime res1);
Console.WriteLine(res1.ToLongDateString());
DateTime.TryParseExact("1/05/2019", formats, CultureInfo.CurrentCulture, DateTimeStyles.None, out DateTime res2);
Console.WriteLine(res2.ToLongDateString());
DateTime.TryParseExact("2019/05/01", formats, CultureInfo.CurrentCulture, DateTimeStyles.None, out DateTime res3);
Console.WriteLine(res3.ToLongDateString());
Console.ReadLine();
}
2019年五月1日星期三
2019年五月1日星期三
2019年五月1日星期三
您的代碼不工作,因為它考慮到了最后的結果TryParseExact
ONLY行:
args.IsValid = DateTime.TryParseExact(args.Value, "yyyy/MM/dd", new CultureInfo("en-GB"), DateTimeStyles.None, out dt);
先前的結果將丟失。
另外,這部分完全是毫無意義的( 希望您能理解為什么 ):
if (args.IsValid)
{
args.IsValid = true;
}
嘗試以下方法:
if (Regex.IsMatch(txtIssueDate.Text, "(((0|1)[0-9]|2[0-9]|3[0-1])\\/(0[1-9]|1[0-2])\\/((19|20)\\d\\d))$"))
{
DateTime dt;
args.IsValid = (DateTime.TryParseExact(args.Value,
"dd/MM/yyyy",
new CultureInfo("en-GB"),
DateTimeStyles.None,
out dt) ||
DateTime.TryParseExact(args.Value,
"d/MM/yyyy",
new CultureInfo("en-GB"),
DateTimeStyles.None,
out dt) ||
DateTime.TryParseExact(args.Value,
"yyyy/MM/dd",
new CultureInfo("en-GB"),
DateTimeStyles.None,
out dt));
}
else
{
args.IsValid = false;
ScriptManager.RegisterStartupScript(UpdatePanel2, UpdatePanel2.GetType(), "myFunction", "alertInvalidDate();", true);
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.