[解決済み] AngularJSで日付の検証を行う
2022-02-19 13:15:06
質問
angularjsで作成したフォームで未来の日付を許可することができません。
以下は私のHTMLです。
<div ngCloak ng-app="laurelMoney" ng-controller="myCtrl">
<form name="userForm">
<div class="form-group">
<input type='date' id="trandate" class="form-control" ng-model="trandate" required ng-class="{ 'has-error' : userForm.trandate.$error }" />
<p ng-show="userForm.trandate.$error" class="help-block">Transaction can't be in future</p>
</div>
<a href="#" class="btn btn-primary btn-sm btn-block" ng-click="submitForm()" type="submit">Add Transaction</a>
</form>
そして、私のjavascriptはÑです。
angular.module('laurelMoney', [])
.controller('myCtrl', function($scope) {
var today = new Date();
var dd = today.getDate();
var mm = today.getMonth() + 1;
var yyyy = today.getFullYear();
if (dd < 10) {
dd = '0' + dd
}
if (mm < 10) {
mm = '0' + mm
}
today = yyyy + '-' + mm + '-' + dd;
document.getElementById("trandate").setAttribute("max", today);
$scope.submitForm = function() {
if ($scope.userForm.$valid) {
alert('our form is amazing');
} else {
console.log("Error");
}
};
});
カレンダーがポップアップするときは問題なく動作しています。未来の日付はすべて無効になっていますが、日付入力ボックスで未来の日付に手動で変更することは可能です。
システム上、未来の日付の投稿も可能です。どうすればいいのでしょうか?
ありがとうございます。
解決方法は?
さて、あなたの質問から理解したことは、単にエラーメッセージを投げるか、ユーザーが将来の日付を選択できないようにしようとしている、ということですね?では、これをご覧ください。
注意事項
-
あなたの
Angular
のバージョンは完全に古いので、期待通りに動作しない可能性があります。 -
ngCloak
はng-cloak
; -
を追加する必要があります。
名前
attribute
をあなたのinput
を使用して検証します。 -
また
ngSubmit
の代わりに、フォームを送信するためにng-click
. -
コメントで指摘されているように、無効化することができます。
button
を指定した場合form
はinvalid
でチェックするのではなくcontroller
; -
最後に、日付を最大値として設定する場合(あなたの場合
今日
ということで、以下のようにします。
$scope.max = new Date()
を作成し、ビューでそれを呼び出します。
以下はその完全な例です。
(function() {
'use strict';
angular
.module('laurelMoney', [])
.controller('myCtrl', myCtrl);
myCtrl.$inject = ['$scope'];
function myCtrl($scope) {
$scope.max = new Date();
}
})();
<!DOCTYPE html>
<html>
<head>
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.5.8/angular.min.js"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" />
</head>
<body ng-app="laurelMoney">
<div ng-cloak ng-controller="myCtrl">
<form name="userForm" novalidate ng-submit="submitForm()">
<div class="form-group" ng-class="{ 'has-error' : userForm.trandate.$error }">
<input type="date" name="trandate" class="form-control" required max="{{max}}" ng-model="trandate">
<p ng-if="userForm.trandate.$touched && userForm.trandate.$error.required" class="help-block">Transaction is required</p>
<p ng-if="userForm.trandate.$error.date" class="help-block">Transaction should be a valid date</p>
<p ng-if="userForm.trandate.$error.max" class="help-block">Transaction can't be in future</p>
</div>
<button type="submit" class="btn btn-primary btn-sm btn-block" ng-disabled="userForm.$invalid">Add Transaction</button>
</form>
<pre ng-bind="userForm.trandate.$error | json"></pre>
</div>
</body>
</html>
関連
-
[解決済み】JavaScriptのisset()に相当するもの
-
[解決済み】HTMLの最初の行に予期しないトークン<がある。
-
[解決済み】JavaScriptで「無効な日付」のDateインスタンスを検出する
-
[解決済み] JavaScriptの日付の書式設定方法
-
[解決済み] JavaScriptで現在の日付を取得するには?
-
[解決済み] AngularJSでデータバインディングはどのように機能するのですか?
-
[解決済み] AngularJSを使用して、ブラウザのコンソールで$scope変数にアクセスするにはどうすればよいですか?
-
[解決済み] AngularJSで$scope.$watchと$scope.$applyを使用するにはどうすればよいですか?
-
[解決済み] AngularJS コントローラにおける 'this' と $scope の比較
-
[解決済み】AngularJSのスコーププロトタイピング/プロトタイピング継承のニュアンスとは?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】Facebook Graph API のクエリで with=location を使用すると "Uncaught (in promise) undefined" というエラーが発生する。
-
[解決済み】React Js: Uncaught (in promise) SyntaxError: 位置 0 の JSON で予期しないトークン < が発生しました。
-
[解決済み】document.getElementByIDは関数ではありません。
-
[解決済み] jQueryで、ユーザーがそのフィールドを編集している間、テキストフィールドの最初の文字を大文字にするにはどうすればよいですか?
-
[解決済み】webpack-dev-serverにリモート接続すると、「Invalid Host header」というメッセージが表示されます。
-
[解決済み】XMLHttpRequestモジュールが定義されていない/見つからない
-
[解決済み】BootstrapのCollapseが折りたたまれない
-
[解決済み] エラー。モジュールhtmlが見つからない
-
[解決済み】エラー:リクエストのエンティティが大きすぎる
-
[解決済み】Uncaught ReferenceError。Firebase は定義されていません。