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

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

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

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

Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

Cloud Firestore

Cloud Firestore は、自動スケーリングと高性能を実現し、アプリケーション開発を簡素化するように構築された NoSQLドキュメントデータベースです。

Q&A

解決済

1回答

422閲覧

【Vue.js×Firestoreクエリ】コンパイル直後はクエリによるデータ取得が成功するが、ブラウザリロード後はクエリ実行しても返却値が空になる

knj

総合スコア37

Vue.js

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

Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

Cloud Firestore

Cloud Firestore は、自動スケーリングと高性能を実現し、アプリケーション開発を簡素化するように構築された NoSQLドキュメントデータベースです。

0グッド

0クリップ

投稿2022/04/01 13:35

編集2022/04/01 13:36

Vue.jsでFirestoreにデータ格納しています。
仮ですが、データ構造はこちらです。

json

1// コレクション 2users: { 3 // ドキュメント 4 "000": { 5 // フィールド 6 post_id:1 7 category_id,1 8 },

Create時に書きの関数を実行しています。

javascript

1testMethod: async function() { 2 const userRef = collection(db, 'users'); 3 const q = query(userRef, where('post_id', '==', "1"), where('category_id', '==', "1")); 4 const Snapshot = await getDocs(q); 5 6 Snapshot.forEach((doc) => { 7 if(doc.exists()) { 8 console.log(doc.id) 9 console.log('データあるよ') 10 } else { 11 console.log('データないよ') 12 } 13 }); 14}

コンパイル直後は↑は、クエリオブジェクトが作成・実行され、条件にマッチしたドキュメントデータが返却されます。

ただ、そのあとにブラウザリロードや別タブでページを開くと、返却値がemptyになっています。

再度コンパイルすると、直後のみ正しく実行されます。

かなりつまっています...。

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

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

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

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

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

guest

回答1

0

自己解決

この手前で必要な情報を取得していて、そのpromiseが正しく実装できていないのが原因でした。
解決です。

投稿2022/04/02 07:16

knj

総合スコア37

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問