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

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

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

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

Q&A

0回答

894閲覧

firestoreでのwhere記述について

teddy1121

総合スコア44

JavaScript

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

0グッド

0クリップ

投稿2021/02/01 03:13

編集2021/02/04 05:39

前提・実現したいこと

初めて掲示板を利用させていただくので失礼があったら申し訳ありません。
表題の件につきまして、firestoreを利用して勤怠システムを作成したいと思っています。
getを使ってフィールドの値を取得するのですが、その際whereで絞り込みをしたいと思っています。
色々と調べ、公式の通り(そのつもりなのですが、初心者のため間違っているのかもしれません)書いたつもりなのですが、コンソールでエラーは出ないのにwhereの部分が無視(?)されてしまいます。
なぜこの現象が起きるのか、どうしたら解消するのかを教えて頂けたら幸いです。
※質問の仕方のマナーもわからないので何か不備があれば併せて教えて頂けたらと思います。

発生している問題・エラーメッセージ

コンソールにエラーメッセージは出ません。 where句の中の最後('test')の部分は出勤時のフィールドに試験的に書き込んだ文字列です。

該当のソースコード

js

1<script> 2 3 document.getElementById("outTimeClk").onclick = function() { 4 5 firebase.firestore().collection(userId).where('outTime','==','test').get().then((snapShot)=> { 6 if (snapShot.exists) { 7 alert("退勤しています") 8 }else{ 9

試したこと

collection(userId).doc(dateToday).collection(dateToday).where('outTime','==','test').get~
などwhereの前を色々と変えてみましたがダメでした。
試したことが的外れだったら申し訳ありません。

補足情報(FW/ツールのバージョンなど)

dateTodayは本日の日付を定義してあります。
outTimeはフィールド名です。
collection:userId
doc:dateToday
イメージしているのはuserIdコレクションのdateTodayドキュメント配下にあるoutTimeフィールドをwhereを使って値の有無を判断し、存在するなら「退勤しています」と表示させたいです。

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

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

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

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問