質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

1回答

1781閲覧

jQuery 日付判定のif文を書きたい

inadamaru

総合スコア4

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

1クリップ

投稿2020/09/24 00:37

編集2020/09/24 02:16

###内容
jQuery初心者です。

jQueryで、デイトピッカーによって入力された日付が有効かどうか判定する式を書きたいです。
※手入力の可能なデイトピッカーを使用しているため。

かつその日付欄は必須ではありません。
なので入力があればその日付が有効か判定。
→無効な日付であればエラーメッセージを表示
入力が無ければ
→エラーメッセージは表示しない

という構造にしたいです。
現状書いているコードは以下なのですが、空白でも無効な日付でもエラーメッセージが表示されてしまいます。
本当に初歩的な質問で申し訳ありませんが、どなたか教えていただけると幸いです。

JavaScript

1jQuery(function(){ 2 jQuery('#push').click(function() { 3 const date1 = new Date(jQuery('[data-name="start"]').find('.input.hasDatepicker').val()); 4 let error_flag = false; 5 jQuery('.notice').remove(); 6 7 //日付の型チェック 8 if(date1.length !== "" && date1.toString() === "Invalid Date") { 9 error_flag = true; 10 jQuery('[data-name="start"]').find('.input').prepend('<div class="notice error-message"><p>正しい日付を入力してください</p></div>'); 11 } 12 if(error_flag === true) { 13 return false; 14 } 15 }); 16 }); 17 </script>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

###原因
Date型に変換したdate1からlenghthを取ってきていたことが原因でした。

###解決方法
date1ではなく、要素が空かどうかを判定することで解決しました。
(誤)if(date1.length !== "" && date1.toString() === "Invalid Date")
(正)if(jQuery('[data-name="start"]').find('.input.hasDatepicker').val() !== "" && date1.toString() === "Invalid Date")

投稿2020/09/24 02:15

inadamaru

総合スコア4

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問