如何确定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>
答案 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;
}