Visual Studio 2019にてWebアプリケーション(Webページ)を作成しています。
.Net FrameworkはVer4.8です。
運用ルールで使用ブラウザはChromeに限定しております。
日付入力で本日より先(未来)の日付入力を不可とするために、CustomValidatorを使用しています。
サーバーサイドでの比較はできているのですが、クライアントサイドの比較においてjavascriptで記述するのですが、javascriptに詳しくないためどうしたらよいのか途方に暮れております。
Webで調べたりしいくつか方法を試しましたが、いまだ解決に至っておりません。
現状のCodeは下記の通りです。(基本がわかっていないので見当はずれがあると思います)
Html
1<html> 2<head> 3<script type="text/javascript"> 4 5 function cusDate_Validate(sender, args) { 6 var today = new Date(); 7 var tb = document.getElementById('<%= txtDate.ClientID %>').split('/') 8 return new Date(tb[0],tb[1] -1,tb[2]); 9 10 if ( tb > today ) { 11 args.IsValid = False; 12 } else { 13 args.IsValid = True; 14 } 15 } 16 17</script> 18<title>クライアント検証のテスト(CustomValidatorコントロール)</title> 19</head> 20<body> 21<form runat="Server"> 22タイトル: 23<asp:TextBox id="txtDate" runat="Server" Size="35" TextMode="Date" /> 24<asp:CustomValidator id="cusDate" runat="Server" 25 ControlToValidate="txtDate" ClientValidationFunction="cusDate_Validate" 26 OnServerValidate="cusDate_Validate" Display="Dynamic" 27 ErrorMessage="未来の日付は入力できません。" /> 28<br /> 29<asp:Button id="btnSend" runat="Server" Text="送信" /> 30</form> 31</body>
参考にしたサイトの参考箇所は下記の通りです。
最終的には一番上のサイトの情報が実現したいことに一番近かったので真似ています。
https://zukucode.com/2017/04/javascript-string-date.html
JavaScript 文字列を日付オブジェクトに変換する
// str: 日付文字列(yyyy-MM-dd, yyyy/MM/dd)
// delim: 区切り文字("-", "/"など)
function toDate (str, delim) {
var arr = str.split(delim)
return new Date(arr[0], arr[1] - 1, arr[2]);
};
var str = '2017/01/02'
var date = toDate(str, '/');
https://www.sejuku.net/blog/22867
https://www.sejuku.net/blog/23115#ltgt
https://mebee.info/2020/12/07/post-18467/
http://surferonwww.info/BlogEngine/post/2020/06/27/validation-of-customvalidator-on-client-side.aspx
何卒アドバイスの程よろしくお願いいたします。
回答2件
あなたの回答
tips
プレビュー