如何检查或验证文本框输入的日期是DD/MM/YYYY
格式?
答案 0 :(得分:18)
标记:
<asp:Textbox runat="server" ID="TextBox1" />
<asp:CustomValidator runat="server" ControlToValidate="TextBox1" ErrorMessage="Date was in incorrect format" OnServerValidate="CustomValidator1_ServerValidate" />
代码隐藏:
protected void CustomValidator1_ServerValidate(object sender, ServerValidateEventArgs e)
{
DateTime d;
e.IsValid = DateTime.TryParseExact(e.Value, "dd/MM/yyyy", CultureInfo.InvariantCulture, DateTimeStyles.None, out d);
}
如果您想要允许多种格式而只允许使用它们,请使用下一步:
DateTime.TryParseExact(e.Value, new[] { "dd/MM/yyyy", "yyyy-MM-dd" }, CultureInfo.InvarinatCulture, DateTimeStyles.None, out d);
答案 1 :(得分:4)
另一个选择是使用正则表达式验证器。下面的正则表达式检查DD / MM / YYYY但当然没有办法区分01之类的东西是DD还是MM。否则就可以了。
<asp:TextBox ID="txtDate" runat="server"/>
<asp:RegularExpressionValidator ID="regexpName" runat="server"
ErrorMessage="This expression does not validate."
ControlToValidate="txtDate"
ValidationExpression="^(0[1-9]|[12][0-9]|3[01])[- /.](0[1-9]|1[012])[- /.](19|20)\d\d$" />
答案 2 :(得分:1)
DateTime Result;
DateTimeFormatInfo info = new DateTimeFormatInfo ( );
CultureInfo culture;
culture = CultureInfo.CreateSpecificCulture ( "en-US" );
info.ShortDatePattern = "dd/MM/yyyy";
if ( DateTime.TryParse ( StrDate, info, DateTimeStyles.None, out Result ) )
{
return StrDate;
}
答案 3 :(得分:0)
您可以使用CustomValidator检查输入的值是否在设置参数范围内 即13/12/2001有效但12/13/2001无效。
答案 4 :(得分:0)
您可以使用自定义验证器检查文本框中的任何内容,但使用CompareValidator检查文本是否可以转换为日期可能更容易。
我在这里找到了一个示例(在VB中,但很容易阅读并转换为C#):http://quickstarts.asp.net/QuickStartv20/aspnet/doc/validation/default.aspx
但是,使用某种日期选择器控件可能更加用户友好。
答案 5 :(得分:0)
您最好使用日历控件,但如果您想检查日期字符串,请使用以下代码验证是否为DD / MM / YYYY格式。
DateTime dt;
if (!DateTime.TryParse(texbox.Text, new System.Globalization.CultureInfo("en-GB"), System.Globalization.DateTimeStyles.None, dt))
{
// text is not in the correct format
}
答案 6 :(得分:0)
我的方法是使用regexvalidator进行第一次快速测试(“它看起来可能是一个日期”)客户端。然后是一个带有服务器端事件的CustomValidator,它尝试使用我的格式执行DateTime.Parse,以排除像“29 feb 2010”这样的日期。
我个人不相信CompareValidator,因为我不确定它使用的是什么格式(但这可能是因为我没有进行足够的调查)。
答案 7 :(得分:-2)
你做不到。用户可以使用某种日期时间选择器。示例here。