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

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

新規登録して質問してみよう
ただいま回答率
85.49%
Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

1回答

255閲覧

条件分岐のネストがわかりません

mori.

総合スコア7

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

1グッド

1クリップ

投稿2018/06/01 16:35

編集2018/06/01 17:47

javascript初心者です。(プログラミング初心者)お手柔らかにお願いします。

フォームで、今の日付と入力された日付の比較をして、今の日付より入力された日付が昔だったら(今の日付>入力された日付)エラーメッセージを表示するようなプログラムを書きたいです。

Javascript

1 2data() =>({ 3 event: = null, // YYYY/MM/DDではいってくる 4 err_msg = null, // エラーメッセージ 5}), 6methods: { 7 this.err_msg = ""; 8 check(event) { 9// 入力された日付を区切る(例)2018/05/31 → 2018 05 31 10 var eve = event.split('/'); 11// システム日付(現在) 12 var now = new date(); 13 var year = now.getFullYear(); 14 var month = now.getMonth() + 1; 15 var date = now.getDate(); 16 17// チェック 18if(eve[0]=== year) { 19 if(eve[1]=== month) { 20 if(eve[2]< date) { 21 this.err_msg = "dateエラー" 22 return; 23 } else if(eve[1] < month) { 24 this.err_msg = "monthエラー" 25 return; 26} else if(eve[0] < year) { 27 this.err_msg = "yearエラー" 28 return; 29} 30

ややこしいのと読みづらいのですみません、上記のようなソースをわかりやすくするアドバイスがいただきたいです。実際にローカルで動かしたりできていないので間違っていたらおしえてください。
また、日付の入力フォームは複数あって上記のeventの名前以外は同じ処理をするのですが、1つのチェックメソッドを呼んでtrue/falseで返すようなことをしたいです。が、今はやりかたがわからず同じような処理をするチェックメソッドを何個も作ってしまっているような状態です。(フラグの使い方がよくわからない)
稚拙な説明ですがご協力いただければありがたいです。

DrqYuto👍を押しています

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

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

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

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

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

mather

2018/06/01 17:41

これ、もしかしてVue.jsのソースコードの一部でしょうか?
mori.

2018/06/01 17:48

そうです!タグつけ忘れてました・・・
mather

2018/06/01 17:52

だとすると、もうちょっとVue.jsそのものを勉強した方がいいと思います。methodsの書き方がおかしくて、さらにソースコードのとじカッコがないのでぐちゃぐちゃになってますよ…。
karamarimo

2018/06/02 01:54

コードはなるべくそのまま実行できる形で載せてください。今の場合 new Vue({ ... }) の中だけを載せていると思いますが、外側も省略せずに載せてください。
euledge

2018/06/02 05:00 編集

質問者がその前に行った質問 [JavaScriptでの日付チェックの方法](https://teratail.com/questions/128989)でベストアンサーとされていた方法でDatapickerで取得された文字列に関して区切り文字を除いて比較すればよいとされていたので、そもそも年月日を分けて比較する必要はないのではないでしょうか? Date()で得られた日付に対してのYYYYMMDDでのフォーマットを関数にしてしまえばよいのかと思います。
guest

回答1

0

結果的に過去の日付を弾きたいのであれば、年月日を分けて比較する必要はないように思います。
日付文字列から比較するのであれば、getTime()でUnix時間に変換して比較することで過去か未来かを判別できます。

js

1function isFutureDate(event) { 2 // eventはYYYY/MM/dd 3 const input = new Date(event).getTime(); 4 const now = new Date().getTime(); 5 return now < input; 6}

実はJavaScriptのDateは比較演算子で比較可能なので、このようにも書けます。

js

1function isFutureDate(event) { 2 return new Date() < new Date(event); 3}

投稿2018/06/02 09:09

keroxp

総合スコア114

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問