我正在尝试使用ASP.NET RangeValidator
来验证文本框上的日期。在文本框中输入的日期格式为dd MMMM yyyy
。
如何使用范围验证器验证有效日期?如果我输入 1月1日1000 作为最小值或最大值,我会收到错误消息,说明值无法转换为类型日期,但如果我使用其他格式,则会将输入的文本作为无效格式。
以下是我的代码:
<asp:TextBox
runat="server"
ID="txtDatecompleted"
/>
<cc2:CalendarExtender
ID="datecompletedExtender"
runat="server"
TargetControlID="txtDatecompleted"
Format="dd MMMM yyyy"
/>
<asp:RangeValidator
runat="server"
ID="RangeValidator1"
Type="Date"
ControlToValidate="txtDatecompleted"
MaximumValue="9999/12/28"
MinimumValue="1000/12/28"
ErrorMessage="enter valid date"
Display="None"
/>
<cc2:ValidatorCalloutExtender
ID="RangeValidator1_ValidatorCalloutExtender"
runat="server"
Enabled="True"
TargetControlID="RangeValidator1">
</cc2:ValidatorCalloutExtender>
答案 0 :(得分:127)
最好的选择是
在网络表单中添加比较验证器。设置其controlToValidate。将其Type属性设置为Date。将其operator属性设置为DataTypeCheck,例如:
<asp:CompareValidator
id="dateValidator" runat="server"
Type="Date"
Operator="DataTypeCheck"
ControlToValidate="txtDatecompleted"
ErrorMessage="Please enter a valid date.">
</asp:CompareValidator>
答案 1 :(得分:28)
CustomValidator也可以在这里工作:
<asp:CustomValidator runat="server"
ID="valDateRange"
ControlToValidate="txtDatecompleted"
onservervalidate="valDateRange_ServerValidate"
ErrorMessage="enter valid date" />
代码隐藏:
protected void valDateRange_ServerValidate(object source, ServerValidateEventArgs args)
{
DateTime minDate = DateTime.Parse("1000/12/28");
DateTime maxDate = DateTime.Parse("9999/12/28");
DateTime dt;
args.IsValid = (DateTime.TryParse(args.Value, out dt)
&& dt <= maxDate
&& dt >= minDate);
}
答案 2 :(得分:7)
我认为以下是最简单的方法。
<asp:TextBox ID="DateControl" runat="server" Visible="False"></asp:TextBox>
<asp:RangeValidator ID ="rvDate" runat ="server" ControlToValidate="DateControl" ErrorMessage="Invalid Date" Type="Date" MinimumValue="01/01/1900" MaximumValue="01/01/2100" Display="Dynamic"></asp:RangeValidator>
答案 3 :(得分:2)
我认为日期必须在应用程序的当前文化中指定。您可能希望尝试将CultureInvariantValues设置为true,然后查看是否可以解决您的问题。否则,您可能需要更改当前文化的DateTimeFormat(或culture本身)以获得您想要的内容。