gpt4 book ai didi

asp.net - 将 CompareValidator 和 CalenderExtender 与不受支持的日期格式一起使用

转载 作者:行者123 更新时间:2023-12-01 12:56:08 25 4
gpt4 key购买 nike

我在表单中有一个开始日期和结束日期字段。我已经指定了日历扩展器的格式。从那时起,比较验证器就不起作用了。它始终显示错误消息。请帮忙。我需要以“2012 年 5 月 4 日星期五”的格式显示日期。

开始日期字段:

<asp:TextBox ID="txtStartDate" ReadOnly="true" runat="server" 
CssClass="textBoxWidth TPRValue" Text='<%#DataBinder.Eval(Container.DataItem, "StartDate", "{0: ddd MM dd, yyyy}")%>'>
</asp:TextBox>
<asp:ImageButton ID="imgBtnStartDate" runat="server" ImageUrl="~/Common/Images/Calendar.GIF" CausesValidation="false" ImageAlign="AbsMiddle" />
<ajax:CalendarExtender ID="StartDateCalendar" TargetControlID="txtStartDate" PopupButtonID="imgBtnStartDate" runat="server"
Format="ddd MM dd, yyyy">
</ajax:CalendarExtender>
<asp:CompareValidator ID="startDateCompareValidator" runat="server" ControlToValidate="txtStartDate" ControlToCompare="txtEndDate" Enabled="true"
Type="Date" Display="Dynamic" Operator="LessThanEqual"
Text="Startdate should be <= enddate">
</asp:CompareValidator>

结束日期字段:

<asp:TextBox ID="txtEndDate" ReadOnly="true" runat="server" 
CssClass="textBoxWidth TPRValue" Text='<%#DataBinder.Eval(Container.DataItem, "EndDate", "{0: ddd MM dd, yyyy}")%>'>
</asp:TextBox>
<asp:ImageButton ID="imgBtnEndDate" runat="server" ImageUrl="~/Common/Images/Calendar.GIF" CausesValidation="false" ImageAlign="AbsMiddle" />
<ajax:CalendarExtender ID="EndDateCalendar" TargetControlID="txtEndDate" PopupButtonID="imgBtnEndDate" runat="server"
Format="ddd MM dd, yyyy">
</ajax:CalendarExtender>

比较验证器:

<asp:CompareValidator ID="startDateCompareValidator" runat="server" ControlToValidate="txtStartDate" 
ControlToCompare="txtEndDate" Enabled="true" Type="Date" Display="Dynamic" Operator="LessThanEqual"
Text="Startdate should be <= enddate">
</asp:CompareValidator>

最佳答案

我假设 CompareValidator 不接受您的格式。

CompareValidator 对其接受的日期非常讲究。例如,以下日期被视为无效:

  • 2001 年 1 月 1 日
  • 2001 年 1 月 1 日
  • 2012 年 5 月 4 日星期五

CompareValidator 需要一个如下所示的日期:

  • 2001 年 1 月 1 日
  • 2001 年 1 月 1 日
  • 2012 年 5 月 4 日

http://www.informit.com/articles/article.aspx?p=25461&seqNum=5

无需测试,您可以尝试使用隐藏的 TextBox(display:none),并将接受的日期格式作为文本。然后将 Validator 的 ControlToValidate 设置为“hiddenfield”。您需要将两个文本框的文本属性与其隐藏字段同步。也许这会给你一个想法。

编辑:好的,我已经尝试让它按我所说的那样工作,实际上它正在工作:)也许有一些重构的可能,但你自己看看。

要隐藏工作日期格式的文本框,我使用了 CSS:

<style type="text/css">
.hidden
{
display:none;
}
</style>

当用户通过 CalendarExtenders 更改日期时调用这些 JS 函数:

<script type="text/javascript">
function dateChangedStart(sender, args) {
var selectedDate = sender.get_selectedDate();
var hiddenStart = $get("txtStartDateHidden");
var validator = $get("startDateCompareValidator");
hiddenStart.value = dateToString(selectedDate);
ValidatorValidate(validator);
}
function dateChangedEnd(sender, args) {
var selectedDate = sender.get_selectedDate();
var hiddenEnd = $get("txtEndDateHidden");
var validator = $get("startDateCompareValidator");
hiddenEnd.value = dateToString(selectedDate);
ValidatorValidate(validator);
}
function dateToString(d) {
var year = d.getFullYear();
var month = d.getMonth() + 1; //months are zero based
var day = d.getDate();
return year + "/" + month + "/" + day;
}
</script>

这是示例页面的其余部分:

<div>
<asp:TextBox ID="txtStartDate" CausesValidation="false" ReadOnly="true" runat="server">
</asp:TextBox>
<asp:TextBox ID="txtStartDateHidden" CssClass="hidden" ValidationGroup="DateCheck" CausesValidation="true" ReadOnly="false" runat="server">
</asp:TextBox>
<ajax:CalendarExtender ID="StartDateCalendar" TargetControlID="txtStartDate" runat="server"
OnClientDateSelectionChanged="dateChangedStart"
Format="ddd MM dd, yyyy">
</ajax:CalendarExtender>
<asp:CompareValidator ID="startDateCompareValidator" runat="server" EnableClientScript="true"
ControlToValidate="txtStartDateHidden" Display="Static" Operator="LessThanEqual" ValidationGroup="DateCheck"
ControlToCompare="txtEndDateHidden" Enabled="true" Type="Date" Text="Startdate should be <= enddate">
</asp:CompareValidator>
<asp:TextBox ID="TxtEndDate" CausesValidation="false" ReadOnly="true" runat="server">
</asp:TextBox>
<asp:TextBox ID="txtEndDateHidden" CssClass="hidden" ValidationGroup="DateCheck" CausesValidation="true" ReadOnly="false" runat="server">
</asp:TextBox>
<ajax:CalendarExtender ID="EndDateCalendar" TargetControlID="txtEndDate" runat="server"
OnClientDateSelectionChanged="dateChangedEnd"
Format="ddd MM dd, yyyy">
</ajax:CalendarExtender>
<asp:Button ID="BtnSubmit" CausesValidation="true" ValidationGroup="DateCheck" runat="server" Text="Submit" />
</div>

关于asp.net - 将 CompareValidator 和 CalenderExtender 与不受支持的日期格式一起使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9735836/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com