[英]Future date validation in asp.net using javascript
下面提到的代码已用于验证未来日期,但无法正常工作。 任何帮助表示赞赏。 文本框的readonly属性设置为false,因此我可以更改文本框中的值并更改为将来的日期,为此我需要验证
//在aspx中
<asp:TextBox ID="txtdob" runat="server" OnClientDateSelectionChanged="checkDate"></asp:TextBox>
<asp:Button ID="Button2" runat="server" onclick="Button2_Click" Height="26px" Width="23px" Text=".." />
<script type="text/javascript" >
function checkDate(sender, args)
{
if (sender._selectedDate > new Date())
{
alert("You cannot select future date!");
sender._selectedDate = new Date();
// set the date back to the current date
sender._txtdob.set_Value(sender._selectedDate.format(sender._format))
}
}
</script>
<asp:Calendar ID="Calendar1" runat="server" onselectionchanged="Calendar1_SelectionChanged" OnClientDateSelectionChanged="checkDate"
style="top: 320px; left: 246px; position: absolute; height: 188px; width: 259px">
</asp:Calendar>
//在C#中
protected void Button2_Click(object sender, EventArgs e)
{
Calendar1.Visible = true;
}
protected void Calendar1_SelectionChanged(object sender, EventArgs e)
{
txtdob.Text = Calendar1.SelectedDate.ToShortDateString();
}
此解决方案不会针对每个请求进行验证,但是会使所有日期都无法选择
protected void Calendar1_DayRender(object sender, DayRenderEventArgs e)
{
endDate = DateTime.Today;
e.Day.IsSelectable = e.Day.Date <= endDate;
}
请注意, DayRenderEventArgs
位于命名空间System.Web.UI.WebControls
OnClientDateSelectionChanged不是用于ASP日历控件的有效方法。 这是用于ajax压延机控制的方法。 检查此链接
首先下载免费的Ajax工具套件,然后在“ 工具箱”中添加一个新选项卡,然后选择项目并浏览以查找Ajax Control ToolKit dll文件。 该工具套件将添加到工具箱,然后从ajax工具套件中选择一个日历扩展器。 然后在aspx页面中,在ContentPlaceHolder之前添加以下代码行
<%@ Register Assembly="AjaxControlToolkit" Namespace="AjaxControlToolkit" TagPrefix="asp" %>
然后在Content Place Holder中添加JavaScript。
<script type="text/javascript">
function checkDate(sender, args)
{
if (sender._selectedDate > new Date())
{
alert("You cannot select future date!");
sender._selectedDate = new Date();
// set the date back to the current date
sender._textbox.set_Value(sender._selectedDate.format(sender._format))
}
}
</script>
然后对于文本框使用此代码。
<asp:TextBox ID="txtdob" runat="server" ></asp:TextBox>
<asp:CalendarExtender runat="server" ID="CalenderExtender1" Format="MM/dd/yyyy" OnClientDateSelectionChanged="checkDate"
TargetControlID="txtdob">
</asp:CalendarExtender>
这可能会解决您的问题。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.