验证文本框中的日期

时间:2013-01-14 07:59:28

标签: c# asp.net datetime textbox

如何确定textbox中的值是否正确date

例如: 这是我的文本框中日期的值:01/32/2013

我知道这是一个错误的日期值,但我怎么能确定它是一个错误的格式? 我可以使用 try and catch 来避免这种情况,但我不想使用它,如果我在问题中找不到解决方案,我会使用它。

<asp:TextBox ID="txtMEditStartDt" runat="server" Text='<%# Bind("StartDt", "{0:MM/dd/yyyy}") %>'
    CssClass="datePicker" SkinID="textSkin" Width="100px"></asp:TextBox>
<asp:MaskedEditExtender ID="MaskedEditStartDt" runat="server"
    TargetControlID="txtMEditStartDt" Mask="99/99/9999" MaskType="Date" 
    CultureAMPMPlaceholder="" CultureCurrencySymbolPlaceholder="" 
    CultureDateFormat="" CultureDatePlaceholder="" CultureDecimalPlaceholder="" 
    CultureThousandsPlaceholder="" CultureTimePlaceholder="" Enabled="True"/>
<asp:CalendarExtender ID="calendarEditStartDt" runat="server" TargetControlID="txtMEditStartDt" Format="MM/dd/yyyy">
</asp:CalendarExtender>

3 个答案:

答案 0 :(得分:4)

为什么不使用Calander控件将数据放入文本框而不是允许用户输入日期..这将确保用户不会输入错误的数据值,因为用户只需要从calander控件中选择日期< / p>

如果您知道数据格式,那么

string dateTimeString = "28/08/2012";
DateTime date;
if(DateTime.TryParseExact(dateTimeString, 
   "dd/MM/yyyy", CultureInfo.InvariantCulture,DateTimeStyles.None, 
    out date))
 {
    //code to process valid date
 }

如果没有有效日期,则返回false值,这样您就可以验证日期数据

答案 1 :(得分:3)

您可以使用DateTime.TryParse方法。在这种方法中使用的是当前的应用文化。因此,如果失败,它将只返回false

DateTime dateValue = default(DateTime);
if (DateTime.TryParse(dateString, out dateValue)) 
   //SUCCESS 
else 
  //FAILURE

答案 2 :(得分:2)

DateTime dt;

if(DateTime.TryParse("01/32/2013",out dt)){


  //do stuff;
}